转载于:xiaozhuaixifu 链接地址:http://blog.csdn.net/xiaozhuaixifu/article/details/9004182
“24点游戏是一种使用扑克牌来进行的益智类游戏,游戏内容是:从一副扑克牌中抽去大小王剩下52张,任意抽取4张牌,把牌面上的数(A代表1)运用加、减、乘、除和括号进行运算得出24。每张牌都必须使用一次,但不能重复使用。 有些组合有不同种算法,例如要用2,4,6,12四张牌组合成24点,可以有如下几种组合方法: 2 + 4 + 6 + 12 = 24 4 × 6 ÷ 2 + 12 = 24 12 ÷ 4 × (6 + 2) = 24 当然,也有些组合算不出24,如1、1、1、1 和 6、7、8、8等组合。” --题目描述来自wikipedia:http://zh.wikipedia.org/wiki/24%E7%82%B9。 请完成函数can24,4张牌如果可以组成24点,返回1,不能则返回0。 友情提醒: 注意以下这些组合: 1 1 1 10 不可以; 6 6 6 6 可以; 5 5 5 1 可以,即可以用分数,如(5-1/5)*5 = 24; 1 1 1 11 可以;
完成功能函数即可:
- #include <iostream>
- #include <string>
- #include <cmath>
- #include <sstream>
- using namespace std;
- const double wucha=1E-6; //浮点除法有精度损失
- double num[4];
- bool flag; //标记是否成功
- void game24(int n){
- if(n==1){
- if(fabs(num[0]-24)<=wucha){
- flag=1;
- return ;
- }
- }
- if(flag)return ; //找到满足的一组即可
- for(int i=0;i<n;i++)
- {
- for(int j=i+1;j<n;j++)
- {
- double a,b;
- a=num[i];
- b=num[j];
- num[j]=num[n-1]; //用最后一个元素覆盖,注意这里的n在每次递归中是要递减的
- num[i] = a + b;
- game24(n-1);
- num[i] = a - b;
- game24(n-1);
- num[i] = b -a;
- game24(n-1);
- num[i]=a*b;
- game24(n-1);
- if (b != 0)
- {
- num[i] = a / b;
- game24(n-1);
- }
- if (a != 0)
- {
- num[i] = b / a;
- game24(n-1);
- }
- num[i]=a;
- num[j]=b;
- //递归恢复
- }
- }
- }
- int can24(int a, int b, int c, int d){
- num[0]=double(a);
- num[1]=double(b);
- num[2]=double(c);
- num[3]=double(d);
- flag=0;
- game24(4);
- if(flag)return 1;
- else return 0;
- }
- int main()
- {
- cout<<can24(6,6,6,6)<<endl;
- cout<<can24(1,1,1,10)<<endl; //不可以
- cout<<can24(5,5,5,1)<<endl;
- cout<<can24(1,1,1,11)<<endl;
- return 0;
- }