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

被折叠的 条评论
为什么被折叠?



