由于没有括号,只有+,-,++,--,优先级简单,所以处理起来很简单。

题目要求计算表达式的值以及涉及到的变量的值。

我这题使用stl的string进行实现,随便进行练手,用string的erase删掉全部空格,然后对++、--进行处理然后删去,最后就只剩简单式子了,简单循环下就出来了。

这里有几个坑点:

1.erase函数删除字符后,后面字符的下标都会发生变化,刚开始使用i++去检查空格,结果删除后会跳掉字符。

2.++、--的后缀处理要注意,我开了两个数组放后缀运算的。

3.输出的变量值是当前后自增后的数。

唉,我发现我每次写stl,代码都很乱哪,果然缺欠练习呢。

代码:

  1. #include <iostream>
  2. #include <string>
  3. using namespace std;
  4.  
  5. int v[27], used[27];
  6. int p[27], m[27]; //record the i++ i--
  7.  
  8. int main() {
  9. string str;
  10. while (getline(cin, str) != NULL) {
  11. cout << "Expression: " << str << endl;
  12. int value = 0;
  13. for (int i = 0; i < 26; i++)
  14. v[i] = i + 1, used[i] = p[i] = m[i] = 0;
  15. for (int i = 0; i < str.size();)
  16. if (str[i] == ' ')
  17. str.erase(i, 1);
  18. else
  19. i++;
  20. size_t f1, f2;
  21. while (1) {
  22. f1 = str.find("++");
  23. if (f1 != string::npos) {
  24. if (str[f1 - 1] >= 'a' && str[f1 - 1] <= 'z')
  25. p[str[f1 -1] - 'a']++;
  26. else
  27. v[str[f1 + 2] - 'a']++;
  28. str.erase(f1, 2);
  29. }
  30. // cout << str << endl;
  31. f2 = str.find("--");
  32. if (f2 != string::npos) {
  33. if (str[f2 - 1] >= 'a' && str[f2 - 1] <= 'z')
  34. m[str[f2 -1] - 'a']--;
  35. else
  36. v[str[f2 + 2] - 'a']--;
  37. str.erase(f2, 2);
  38. }
  39. if (f1 == string::npos && f2 == string::npos)
  40. break;
  41. // cout << str << endl;
  42. }//while
  43. // cout << value << endl;
  44. value += v[str[0] - 'a'];
  45. used[str[0] - 'a'] = 1;
  46. for (int i = 1; i < str.size(); i++) {
  47. if (str[i++] == '+')
  48. value += v[str[i] - 'a'], used[str[i] - 'a'] = 1;
  49. else
  50. value -= v[str[i] - 'a'], used[str[i] - 'a'] = 1;
  51. // cout << str[i-1] << str[i]<<' ' << value << endl;
  52. }//for
  53. cout << " value = " << value << endl;
  54. for (int i = 0; i < 26; i++)
  55. if (used[i])
  56. cout << " " << char('a' + i) << " = "<< v[i] + p[i] + m[i] << endl;
  57. }//while
  58. return 0;
  59. }

uva 327 Evaluating Simple C Expressions 简易C表达式计算 stl模拟的更多相关文章

  1. UVA 327 -Evaluating Simple C Expressions(栈)

    Evaluating Simple C Expressions The task in this problem is to evaluate a sequence of simple C expre ...

  2. uva 327 - Evaluating Simple C Expressions

     Evaluating Simple C Expressions  The task in this problem is to evaluate a sequence of simple C exp ...

  3. uva 1567 - A simple stone game(K倍动态减法游戏)

    option=com_onlinejudge&Itemid=8&page=show_problem&problem=4342">题目链接:uva 1567 - ...

  4. Simplifying Conditional Expressions(简化条件表达式)

    1.Decompose Conditional(分解条件表达式) 2.Consolidate Conditional Expressions(合并条件表达式) 3.Consolidate Duplic ...

  5. UVA - 11954 Very Simple Calculator 【模拟】

    题意 模拟二进制数字的位运算 思路 手写 位运算函数 要注意几个坑点 一元运算符的优先级 大于 二元 一元运算符 运算的时候 要取消前导0 二元运算符 运算的时候 要将两个数字 数位补齐 输出的时候 ...

  6. UVa 10012 - How Big Is It? 堆球问题 全排列+坐标模拟 数据

    题意:给出几个圆的半径,贴着底下排放在一个长方形里面,求出如何摆放能使长方形底下长度最短. 由于球的个数不会超过8, 所以用全排列一个一个计算底下的长度,然后记录最短就行了. 全排列用next_per ...

  7. OAuth2简易实战(二)-模拟客户端调用

    1. OAuth2简易实战(二) 1.1. 目标 模拟客户端获取第三方授权,并调用第三方接口 1.2. 代码 1.2.1. 核心流程 逻辑就是从数据库读取用户信息,封装成UserDetails对象,该 ...

  8. Boolean Expressions POJ - 2106 (表达式求值)

    The objective of the program you are going to produce is to evaluate boolean expressions as the one ...

  9. 【STL+模拟】UVa 506 - System Dependencies

    System Dependencies  Components of computer systems often have dependencies--other components that m ...

随机推荐

  1. java 对excel操作导入excel数据到数据库

    加入jar包jxl.jar ===================services层掉用工具类==================================== // 导入 public Lis ...

  2. mvc中ajax.beginform一次提交重复Post两次的问题解决

    在MVC4中使用ajax.beginform来做添加商品到购物车中的提交操作,结果点击提交按钮后,出现两次post,这样导致商品的数量增加了一倍. 原因:@Scripts.Render("~ ...

  3. Pyqt5.2.1生成的.ui文件转换成.py

    cmd C:\>pyuic5 ui文件路径 -o 要生成的py文件路径 如下: C:\>pyuic5 c:\python33\lib\site-packages\pyqt5\uic\log ...

  4. Spring 常用工具类

    1) 请求工具类 org.springframework.web.bind.ServletRequestUtils //取请求参数的整数值: public static Integer getIntP ...

  5. 开发中,如何配合后端,保存你的静态html页

    添加备注2015.4.8 最终决定采用相对路径方法, /img/img.jpg这种“绝对”路径写法必须在网站环境中才能识别,不利于静态页面的查看,故不予采用! 所以采用img/img.jpg或../i ...

  6. Java字面常量与常量池

    Java中的字面常量(区别于final创建的有名常量)通常会保存在常量池中,常量池可以理解为像堆一样的内存区域.但是常量池有一个特性就是,如果常量池中已存在该常量将不会再次为该常量开辟内存 还是看个程 ...

  7. 理解MapReduce哲学

    Google工程师将MapReduce定义为一般的数据处理流程.一直以来不能完全理解MapReduce的真义,为什么MapReduce可以“一般”? 最近在研究Spark,抛开Spark核心的内存计算 ...

  8. jQuery hover事件鼠标滑过图片半透明标题文字滑动显示隐藏

    1.效果及功能说明 hover事件制作产品图片鼠标滑过图片半透明,标题文字从左到右滑动动画移动显示隐藏 2.实现原理 首先把效果都隐藏,然后定义一个伪类来触发所有的效果,接下来当触发伪类后会有一个遍历 ...

  9. [每日一题] OCP1z0-047 :2013-08-06 外表部――相关描述

    这道题目的知识点是要你熟悉外部表,怎么建外部表,外部表的数据是怎么存储的等等.请给出正确答案,并解释A B C D每项,最好用实验测试证明! 外部表的metadata(元数据)是存在数据库中,但它的数 ...

  10. linux 下cocos2dx-3.3.1环境搭建

    1.安装依赖 依赖包含: libx11-dev libxmu-dev libglu1-mesa-dev libgl2ps-dev libxi-dev g++ libzip-dev libpng12-d ...