CCF小白刷题之路---201903-2 二十四点(C/C++ 100分)

简介: CCF小白刷题之路---201903-2 二十四点(C/C++ 100分)

一、题目描述
image.png
image.png
image.png
image.png
image.png
二、代码实现

#include<iostream>
#include<vector>
#include<string>
#include<bits/stdc++.h>
using namespace std;

int main()
{
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        string str;
        cin>>str;
        //存放数字
        vector<int> num;
        //存放运算符
        vector<char> op;
        //把表达式里面的数字和运算符分开存放
        for(int j=0;j<str.length();j++)
        {
            if(str[j]>='0' && str[j]<='9') num.push_back(str[j]-'0');
            else op.push_back(str[j]);
        }
        int j = 0;
        //乘法和除法优先级最高,先处理乘法和除法
        while(j < op.size())
        {
            if(op[j]=='x')
            {
                num[j] = num[j] * num[j+1];
                //乘完之后要把多余元素删除
                //例如
                //num:9 3 4 3
                //op:+ + x
                //进行完乘法运算之后应该变成下面这样
                //num:9 3 12 (3被删除)
                //op:+ + (x被删除)
                num.erase(num.begin() + j + 1);
                op.erase(op.begin() + j);
                j = -1;
            }
            if(op[j]=='/')
            {
                num[j] = num[j] / num[j+1];
                num.erase(num.begin() + j + 1);
                op.erase(op.begin() + j);
                j = -1;
            }
            j++;
        }
        j = 0;
        //处理加法和减法
        while(j < op.size())
        {
            if(op[j]=='+')
            {
                num[j] = num[j] + num[j+1];
                num.erase(num.begin() + j + 1);
                op.erase(op.begin() + j);
                j = -1;
            }
            if(op[j]=='-')
            {
                num[j] = num[j] - num[j+1];
                num.erase(num.begin() + j + 1);
                op.erase(op.begin() + j);
                j = -1;
            }
            j++;
        }
        if(num[0]==24) cout<<"Yes"<<endl;
        else cout<<"No"<<endl;
    }
    return 0;
}
相关文章
|
算法 C语言 C++
从C语言的使用转换到C++(上篇)——刷题、竞赛篇
从C语言的使用转换到C++(上篇)——刷题、竞赛篇
277 0
|
存储 C++
【五一创作】C++刷题 【入门4】数组
【五一创作】C++刷题 【入门4】数组
130 0
|
6月前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-2
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
6月前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-1
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
7月前
|
C语言 C++
【C语言/C++】牛客网刷题训练-12
【C语言/C++】牛客网刷题训练-12
|
7月前
|
存储 自然语言处理 C++
刷题用到的非常有用的函数c++(持续更新)
刷题用到的非常有用的函数c++(持续更新)
89 1
|
存储 C语言 C++
【C/C++刷题——leetcode】查找字符串中最大的子串
【C/C++刷题——leetcode】查找字符串中最大的子串
332 0
|
7月前
|
C++
C++刷题ACM输入数组
C++刷题ACM输入数组
75 0
|
7月前
|
C++
第十三届蓝桥杯B组C++(试题C:刷题统计)
第十三届蓝桥杯B组C++(试题C:刷题统计)
52 0
|
算法 程序员 C语言
从C语言的使用转换到C++(下篇)——刷题、竞赛篇
我们上篇文章讲述了C++中的一些基础语法和常用函数(从C语言的使用转换到C++(上篇)——刷题、竞赛篇),我们本篇文章讲述C++STL的使用。
221 0