题解 | #24点游戏算法#

24点游戏算法

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

将给定的四个数字的所有可能的排列枚举出来,然后对于所有可能的两两数字进行四种运算,每次运算后,数组的大小会减一,当数组大小为2时,计算可能的四种结果并判断是否为24,如果结果为24则输出true,否则输出false。

#include <iostream>
#include <vector>
#include <set>
using namespace std;

void calculate(const vector<double> & nums, bool & flag);

void selectNum(const vector<double> & nums, bool & flag, set<int> orders, vector<double> nums_s) {
    bool selected = true;
    for (int i = 0; i < nums.size(); i++) {
        if (orders.find(i) != orders.end()) {
            nums_s.push_back(nums.at(i));
            orders.erase(i);
            if (nums_s.size() == 4) {
                calculate(nums_s, flag);
                return;
            } else {
                selectNum(nums, flag, orders, nums_s);
            }
            nums_s.erase(--nums_s.end());
            orders.insert(i);
        }
    }
}

void calculate(const vector<double> & nums, bool & flag) {
    if (nums.size() == 2) {
        if (nums.at(0) + nums.at(1) == 24 || nums.at(0) - nums.at(1) == 24 || nums.at(0) * nums.at(1) == 24 || nums.at(0) / nums.at(1) == 24) {
            flag = true;
        }
        return;
    } else {
        vector<double> temp;
        vector<char> operation = {'+', '-', '*', '/'};
        for (char element : operation) {
            for (int i = 0; i < nums.size() - 1; i++) {
                temp.clear();
                for (int j = 0; j < i; j++) {
                    temp.push_back(nums.at(j));
                }
                if (element == '+') {
                    temp.push_back(nums.at(i) + nums.at(i + 1));
                } else if (element == '-') {
                    temp.push_back(nums.at(i) - nums.at(i + 1));
                } else if (element == '*') {
                    temp.push_back(nums.at(i) * nums.at(i + 1));
                } else if (element == '/') {
                    temp.push_back(nums.at(i) / nums.at(i + 1));
                }
                for (int j = i + 2; j < nums.size(); j++) {
                    temp.push_back(nums.at(j));
                }
                calculate(temp, flag);
            }
        }
    }
}

int main() {
    vector<double> nums;
    int number;
    while (cin >> number) {
        nums.push_back(number);
    }
    bool flag = false;
    set<int> orders = {0, 1, 2, 3};
    vector<double> nums_s;
    selectNum(nums, flag, orders, nums_s);
    if (flag) {
        cout << "true";
    } else {
        cout << "false";
    }
    return 0;
}
// 64 位输出请用 printf("%lld")

中等(算法题解) 文章被收录于专栏

中等难度题目

全部评论

相关推荐

深夜书店vv:腾讯是这样的,去年很多走廊都加桌子当工区
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
05-29 22:21
Offer1:小马智行,深圳,测试开发工程师,17.0k*16.0,Offer2:追觅科技,深圳,嵌入式工程师,18.0k*15.0,
嵌软狗都不学:各位base深圳的同事,作为也是并肩作战的一员,今天想站在管理视角,和大家开诚布公地聊一聊:从近几个月的上下班数据对比看来,我们发现一个明显的差异:深圳同事的在岗时间普遍比苏州同事短。很多深圳同事早上9点之后才到公司,晚上不到 20 点就下班了;而总部那边,20点半甚至 22 点后还有不少同事在办公室忙碌,特别是研发团队,加班更是常态。相信去过苏州的同事,对这种场景都不陌生。我很好奇,这是因为苏州工作任务太重还是咱们深圳同事效率真的高到能在更短时间内完成工作?MOVA在深圳成立分公司是为了吸引更优秀的人才贡献更多更高质的价值,公司管理层给我反馈的是深圳招到的多是行业的专家大拿,大部分都是薪资比苏州高的,而且我们办公的租金等也远高于苏州的..MOVA虽脱胎于强壮的集团母体不久,各业务板块尚未实现全面盈利,虽说公司管理层目光长远,不纠结当下的人才投入,但行业内的普遍标准是,员工创造的价值要达到公司雇佣成本的 15 倍以上。大家不妨自我审视一下,自己是否达到了这个标准?如果是抱着划水、按时打卡走人拿毛爷爷的心态那不适合来MOVA,那样过下去不但自己过得尴尬也会影响MOVA这个大船的攻城略地的速度.我并非鼓励大家盲目加班,而是倡导高效工作,拒绝无效忙碌,不要让项目进度因低效受影响,也别把精力浪费在和苏州同事拼打卡时长上,提倡更高的人效比;考虑到两地地域和交通差异,相信大家会找最适合自己发挥的工作方式(比如按时下班后1小时到家晚饭后继续未竟工作等..)大家在遵守公司规章的情况下尽情地体现自己的能力价值,为MOV!和深圳公司争光我们在这边才能更安心更有信心的工作下去;请客BU长、名部门长、项目管理和各业务单元负责人,全面梳理团队情况,及时评估成员工作负荷与成果质量,坚决清退划水害虫痕疫,践行公司价值观,相互监督,防止管理漏洞及渎职。感谢人家的理解,也请人家多担待我的直言不讳……
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务