【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练习系统很坏地改版了,所以只能用所给样例运行一下。

相关推荐
05候补工程师11 分钟前
【408 从零到一】线性表逻辑特征、存储结构对比与 C/C++ 动态内存分配避坑指南
c语言·开发语言·数据结构·c++·考研
rit843249943 分钟前
基于博弈论的小区分簇算法MATLAB实现
开发语言·算法·matlab
华清远见成都中心1 小时前
C 语言内存管理深度解析:malloc/free 与嵌入式堆栈分配策略
java·c语言·算法
怕什么真理无穷1 小时前
C++面试5_ TCP 粘包2(工业级)
开发语言·c++·tcp/ip
一行代码一行诗++1 小时前
关系操作符
算法
努力努力再努力wz1 小时前
【MySQL 进阶系列】拒绝滥用root:从 mysql.user 到权限校验,带你彻底理解用户管理与授权机制!
android·c语言·开发语言·数据结构·数据库·c++·mysql
雪度娃娃1 小时前
基于TCP的网络词典
网络·c++·tcp/ip·c#
生成论实验室1 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第五章 事:行在时空中的具体化
人工智能·算法·架构·知识图谱·创业创新
炸膛坦客2 小时前
嵌入式 - 数据结构与算法:(1-4)数据结构 - 单链表的两个核心缺点(引入循环/双向链表)
c语言·数据结构·链表
Liangwei Lin2 小时前
LeetCode 283. 移动零
算法