【CSP CCF记录】201903-2第16次认证 二十四点

题目

样例1输入

10

9+3+4x3

5+4x5x5

7-9-9+8

5x6/5x4

3+5+7+9

1x1+9-9

1x9-5/9

8/5+6x9

6x7-3x6

6x4+4/5

样例1输出

Yes

No

No

Yes

Yes

No

No

No

Yes

Yes

样例1解释

思路

参考:CCF小白刷题之路---201903-2 二十四点(C/C++ 100分)_ccf认证小白-CSDN博客

(自己写了好几种,发现还是这个最清晰易懂)

本题关键:

  • 字符转数字、字符转运算符
  • 先乘除、后加减

用num和op两个vector分别存储数字和运算符。

第一个for循环进行乘除运算;第二个for循环进行加减运算。

每次运算后,将已经使用过的数字和运算符从容器中删除,需要j--,以防漏算。

可以通过手算改进代码细节。以下以9+3+4x3为例,进行了手算,方便理解。

其他知识点: erase的用法

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int main()
{
	int n;
	cin>>n;
	for(int i=0;i<n;i++)
	{
		string a; 
		cin>>a;
		vector<int> num;//存放数字
		vector<char> op;//存放运算符
		
		for(int j=0;j<a.length();j++) 
		{
			if(a[j]>='0' && a[j]<='9') num.push_back(a[j]-'0');
            else op.push_back(a[j]);
		}
		int j=0;
		for(int j=0; j<op.size();j++)
		{
			if(op[j]=='x')
			{
				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=0;
		for(int j=0; j<op.size();j++)
		{
			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;
			}
		}
		if(num[0]==24)
		{
			cout<<"Yes"<<endl;
		 } 
		 else
		 {
		 	cout<<"No"<<endl;
		 }
	}
	return 0;
}

运行

因为csp练习系统很坏地改版了,所以只能用所给样例运行一下。

相关推荐
CodeClimb2 分钟前
【华为OD-E卷 - 最优资源分配 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
新睿云.任义兵18 分钟前
用 C++ 创建控制台计算器
开发语言·c++
软嵌星芒筑梦师1 小时前
C++之运算符重载详解篇
开发语言·c++
越甲八千1 小时前
带虚继承的类对象模型
c++·类对象模型
带多刺的玫瑰1 小时前
Leecode刷题C语言之切蛋糕的最小总开销②
java·数据结构·算法
robin_suli2 小时前
动态规划回文串问题系列一>回文子串
算法·动态规划
观测云3 小时前
日志聚类算法 Drain 的实践与改良
算法·聚类·日志
心软且酷丶3 小时前
leetcode:面试题 17.01. 不用加号的加法(python3解法)
python·算法·leetcode
Lenyiin3 小时前
《 C++ 点滴漫谈: 十七 》编译器优化与 C++ volatile:看似简单却不容小觑
c++·volatile·lenyiin·c++关键字
hjyowl3 小时前
矩阵Matrix(POJ2155)
算法