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

相关推荐
吃好睡好便好1 天前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅1 天前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
于小猿Sup1 天前
VMware在Ubuntu22.04驱动Livox Mid360s
linux·c++·嵌入式硬件·自动驾驶
x_yeyue1 天前
三角形数
笔记·算法·数论·组合数学
Mr. zhihao1 天前
深入解析redis基本数据结构
数据结构·数据库·redis
念何架构之路1 天前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星1 天前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
小小编程路1 天前
C++ 多线程与并发
java·jvm·c++
失去的青春---夕阳下的奔跑1 天前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光1 天前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生