[题目通道](2 + 2 != 4 - 洛谷)
一道很绕的题。
在手动计算一下之后,你会发现这个运算法则其实就是将运算符的ASCLL码也当做数字计算了进去。
大约就是,你需要把这个算术表达式当做字符串读入,
按照正常的流程,应该先把这个字符串中的数字和运算符分离开,
然后通过对运算符的判断,一 一把各个位于运算符两边的数字按照运算符计算,最后输出答案。
但是这个题是与正常有区别的,
你需要在遇到一个运算符后,也就是在这个运算符之后的数字之前,把这个运算符的ASCLL码当做这个数字的第一位给计算进去。
#include <bits/stdc++.h>
using namespace std;
string a;
int quan=1,ans,ans1;
int main()
{
cin>>a;
for(int i=a.size()-1;i>=0;i--)
{
if(a[i]!='+' && a[i]!='-')
{
ans1+=quan*(a[i]-'0');
quan*=10;
}
else if(a[i]=='+')
{
ans+=quan*(-5)+ans1;
quan=1;
ans1=0;
}
else
{
ans+=quan*3-ans1;
quan=1;
ans1=0;
}
}
ans+=ans1;
cout<<ans;
return 0;
}
标签:,数字,int,ans1,运算符,quan,ans
From: https://blog.csdn.net/2302_78855882/article/details/140947041