24点游戏是经典的纸牌益智游戏。
常见游戏规则:
从扑克中每次取出4张牌。使用加减乘除,第一个能得出24者为赢。(其中,J代表11,Q代表12,K代表13,A代表1),按照要求编程解决24点游戏。
基本要求: 随机生成4个代表扑克牌牌面的数字字母,程序自动列出所有可能算出24的表达式,用擅长的语言(C/C++/Java或其他均可)实现程序解决问题。
1.程序风格良好(使用自定义注释模板)
2.列出表达式无重复。
算法描述:
递归调用的核心思路:
- 在四个数遍历选两个数;
- 计算该组合在此运算符下的结果;
- 将步骤2的结果放入原数组第i个,将最后一个放入原数组的第j个;并对字符串数组赋对应的表达式;
- 对新数组递归调用f,找到一个表达式则返回;
- 将步骤2的结果移除,并将该组合中的两个数重新放回该数组;字符串数组也同理;
C++源码如下:
#include<iostre