题解 | #24点游戏算法#

24点游戏算法

https://www.nowcoder.com/practice/fbc417f314f745b1978fc751a54ac8cb

参考了解答,用枚举遍历的方式实现。
#include <bits/stdc++.h>
using namespace std;

double cal(double a, double b, char ch) {
	switch (ch) {
	case '+':
		return a + b;
	case '-':
		return a - b;
	case '*':
		return a * b;
	case '/':
		return a / b;
	}
    return 0;
}

bool check(vector<int> &nums) {
    char op[4] = {'+','-','*','/'};
    sort(nums.begin(), nums.end());
    do {
        // 遍历三个位置所有可能的
        for (int i = 0; i < 4; i++) {
            for (int j = 0; j < 4; j++) {
                for (int k = 0; k < 4; k++) {
                    double first = cal(nums[0], nums[1], op[i]);
                    double second = cal(first, nums[2], op[j]);
                    if (cal(second, nums[3], op[k]) == 24) return true;
                }
            }
        }
    } while (next_permutation(nums.begin(), nums.end()));
    return false;
}

int main() {
    vector<int> nums;
    for (int i = 0; i < 4; i++) {
        int temp = 0;
        cin >> temp;
        nums.push_back(temp);
    }
    if (check(nums)) { cout << "true" << endl; }
    else { cout << "false" << endl; }
    return 0;
}


全部评论

相关推荐

07-23 15:05
门头沟学院 Java
熊大不大:不好意思KPI数据刚刚刷新,刚刚达标
点赞 评论 收藏
分享
07-09 20:50
门头沟学院 Java
码农索隆:1.教育背景和荣誉证书合二为一。 2.获奖项目理一遍,你做了什么,对你求职的岗位有什么帮助,没有就删掉。 3.技能特长和教育背景交换位置。 4.技能特长写的太差,上网上找简历参考。都不用问你别的,一个redis就能把你问住,写写你具体会redis哪些方面的知识。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务