UVa 327 - Evaluating Simple C Expressions解题报告

题意:模拟计算--,++的计算式

思路:利用stl可以很简单的实现,代码也很清晰明了。首先是利用string类输入数据并清除空格,然后对式子进行扫描,以三个位单位,发现符合x++,x--,--x,++x的情况就对值进行改变,并替换。而对于字母与数字的关系,利用map映照容器建立映射,由于前置和后置对于计算是有不同影响的。使用value存储字母的最终值,用copyvalue存储计算时的字母值,分开存储,输出结果也分开输出,这样思路很直观。

//327 - Evaluating Simple C Expressions
#include <iostream>
#include <string>
#include <map>
#include <cctype>
#include <queue>
#include <algorithm>
using namespace std;
char check(string &, map<char, int> &, map<char, int> &, int);
int main()
{
	//freopen("data.txt", "r", stdin);
	string expression, copy;
	while (getline(cin, expression, '\n'))
	{
		cout << "Expression: " << expression << endl;
		for(int i = 0; i < expression.length(); i++)//预处理,除去所有空格
			if(expression[i] == ' ')
				expression.erase(i--, 1);

		map<char, int> value, CopyValue;//value存储最终每个字母的值,CopyValue存储参与计算式字母的值
		for(int i = 0; i < 26; i++)//建立字母与数字的映射
			value['a' + i] = i + 1;
		CopyValue = value;//建立副本,

		for(int i = 0; i + 2 < expression.length(); i++)//到字符最后第三位即可
		{
			char c = check(expression, value, CopyValue, i);//逐次扫描3个连续字符,返回被改变的字母
			if(c != 0)
				expression.replace(i, 3, 1, c);
		}
		
		int sum = CopyValue[expression[0]];
		for(int i = 1; i + 1 < expression.length(); i++)
		{
			char o = expression[i], x = expression[i + 1];
			if(o == '+')
				sum += CopyValue[x];
			else
				sum -= CopyValue[x];
		}
		printf("    value = %d\n", sum);

		sort(expression.begin(), expression.end());
		for(int i = 0; i < expression.length(); i++)
			if(isalpha(expression[i]))
				printf("    %c = %d\n", expression[i], value[expression[i]]);
	}
}

char check(string &s, map<char, int> &v, map<char, int> &cv,int i)
{
	if(isalpha(s[i]) && s[i + 1] == '+' && s[i + 2] == '+')//判断x++
	{
		v[s[i]]++;
		return s[i];
	}
	else if(isalpha(s[i]) && s[i + 1] == '-' && s[i + 2] == '-')//判断x--
	{
		v[s[i]]--;
		return s[i];
	}
	else if(isalpha(s[i + 2]) && s[i + 1] == '+' && s[i] == '+')//判断++x,前置式对计算结果有影响,所以对于副本值也要改变
	{
		v[s[i + 2]]++;
		cv[s[i + 2]]++;
		return s[i + 2];
	}
	else if(isalpha(s[i + 2]) && s[i + 1] == '-' && s[i] == '-')//判断--x,前置式对计算结果有影响,所以对于副本值也要改变
	{
		v[s[i + 2]]--;
		cv[s[i + 2]]--;
		return s[i + 2];
	}
	else
		return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值