“24点游戏”

题目:

“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 <stdio.h>
#include <math.h>
//4个数据的范围1-13
//a,b,c,d如果可以组成24点,can24返回1,不能则can24返回0
//(此外,你可以在can24内调用你写的另外一个函数)
int flag=0;
double num[4];
double jd=1E-6;

void test(int n)
{
    int i,j;
    double a,b;
     if(n==1){
        if(fabs(num[0]-24)<=jd){
            flag=1;
            return;
        }  
    }
    if(flag){return;}
    for(i=0;i<n-1;i++){
        for(j=i+1;j<n;j++){
            a=num[i];
            b=num[j];
            num[j]=num[n-1];
            num[i]=a+b;
            test(n-1);
            num[i]=a-b;
            test(n-1);
            num[i]=b-a;
            test(n-1);
            num[i]=a*b;
            test(n-1);
            if(a!=0){
                num[i]=b/a;
                test(n-1);
            }
            if(b!=0){
                num[i]=a/b;
                test(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;
    test(4);
    return flag;
}
//start 提示:自动阅卷起始唯一标识,请勿删除或增加。
//可不完成,完成功能函数即可,给定主函数,是为方便你测试
int main(){
        //
    printf("%d\n",can24(1,2,3,4));
    return 0;
}
//end //提示:自动阅卷结束唯一标识,请勿删除或增加。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言编写二十四点游戏(也称为24点游戏或四则运算游戏)是一个经典的编程练习,它主要利用数组和基本数学运算来解决。以下是简单的C语言程序框架,用于实现基本的二十四点算法: ```c #include <stdio.h> #include <stdlib.h> // 定义一个函数,用于计算给定数字数组能否得到24 int is_24(int *nums, int count) { for (int i = 0; i < count; i++) { for (int j = i + 1; j < count; j++) { // 生成所有可能的两数组合 for (int k = j + 1; k < count; k++) { int a = nums[i], b = nums[j], c = nums[k]; // 用剩余的一个数尝试所有运算 for (int op = 0; op < 4; op++) { switch (op) { case 0: // 加法 if (a + b + c == 24 || a + b - c == 24 || a + c - b == 24) return 1; break; case 1: // 减法 if (a + b - c == 24 || a - b + c == 24 || a - c + b == 24) return 1; break; case 2: // 乘法 if (a * b / c == 24 || a * b * c == 24 || a / b * c == 24) return 1; break; case 3: // 除法 if (a * b / c == 24 || a * c / b == 24 || a / b / c == 24) return 1; break; } } } } } return 0; // 如果找不到解决方案,返回0 } int main() { int nums[] = {5, 3, 9, 8}; // 示例输入数组 int count = sizeof(nums) / sizeof(nums); if (is_24(nums, count)) { printf("Solution found: %d + %d * (%d - %d)\n", nums, nums, nums, nums); } else { printf("No solution found.\n"); } return 0; } ``` 这个程序会检查给定的一组数字是否可以通过加、减、乘、除运算得到24。注意,这只是一个基本版本,实际应用中可能需要更复杂的逻辑处理用户输入、错误检查等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值