hiho 98 搜索一 24点

问题

给定四个数, 使用加减乘除四中操作, 得到24, 每个数只能使用一次。

解法

暴力枚举法,
http://hihocoder.com/contest/hiho98/problem/1#

#include <bits/stdc++.h>
using namespace std;
int a[4];
enum{add=0, sub, mul, divid, rsub, rdiv, OPNUM};
int operators[3];
const double ESP = 1e-5;
double Op(double a, double b, int opID)
{
    switch(operators[opID]){
        case add:
            return a+b;
        case sub:
            return a-b;
        case mul:
            return a*b;
        case divid:
            return a/b;
        case rsub:
            return b-a;
        case rdiv:
            return b/a;
    }
}

bool test()
{
    return abs(Op(Op(Op(a[0], a[1], 0), a[2], 1), a[3], 2)-24.0) < ESP ||
    abs(Op(Op(a[0], a[1], 0), Op(a[2], a[3], 2), 1) - 24.0) < ESP;
}

bool result()
{
    do{
        for (int i=0; i< 6*6*6; ++i){
            int a = i;
            operators[0] = a%6;
            a/= 6;
            operators[1] = a%6;
            a/= 6;
            operators[2] = a%6;
            if (test())
                return true;
        }
    }while(next_permutation(a, a+4));
    return false;
}
int main()
{
    int t;
    scanf("%d", &t);
    while(t--){
        scanf("%d %d %d %d", a, a+1, a+2, a+3);
        sort(a, a+4);
        memset(operators, 0, sizeof(operators));
        printf("%s\n", result()? "Yes":"No");
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值