题解 | #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;
}


全部评论

相关推荐

牛客67381407...:我们学校华为是点击就送的
点赞 评论 收藏
分享
专业嗎喽:个人信息名字太大,合到电话邮箱那一栏就行,有党员写过党,剩下其他全删,站空太大了 把实习经历丰富,放最前面,然后是个人评价,技能之类的,然后是学校信息。项目经历最后面,可以就选一个自己擅长的。 现在是学校不是92就扣分的,没必要放前面。 然后现在看重实习经历>竞赛经历(校园经历)>课程项目经历
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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