现在的位置: 首页 > 综合 > 正文

24点问题

2013年10月05日 ⁄ 综合 ⁄ 共 2408字 ⁄ 字号 评论关闭

 

这是求解24点问题的一个解法,考虑到可移植性,我只用了C的标准库函数。
程序是我根据《编程之美》里面的算法写的,使用的基本算法是递归。基本思想是4个数中取两个,
计算后变为3个数,再取2个计算,直到结果为1个数为止,若其值为24就输出该组表达式。
依次遍历所有表达式组合,可以找出所有满足条件的解。
题中规定方案不能重复,加法乘法交换律算不同方案。但如果四个数中有重复的,那么结果就会出现完全重复的情况。
例如:输入2 4 4 5 就会出现2个(5-2)x(4+4)的表达式
虽然这也是交换律导致的,但貌似不符合要求,不知道该怎么解决

 

 

 

 

 

 

这绝对是个C程序,不知道为什么CSDN歧视C.......只好选C++了

 

抱歉!评论已关闭.