title: 表达式求值 第九届省赛 nyoj 1272

tags: [栈,数据结构]

题目链接

描述

假设表达式定义为: 1. 一个十进制的正整数 X 是一个表达式。 2. 如果 X 和 Y 是 表达式,则 X+Y, XY 也是表达式; *优先级高于+. 3. 如果 X 和 Y 是 表达式,则 函数 Smax(X,Y)也是表达式,其值为:先分别求出 X ,Y 值的各位数字之和,再从中选最大数。 4.如果 X 是 表达式,则 (X)也是表达式。 例如: 表达式 12(2+3)+Smax(333,220+280) 的值为 69。 请你编程,对给定的表达式,输出其值。

输入

【标准输入】 第一行: T 表示要计算的表达式个数 (1≤ T ≤ 10) 接下来有 T 行, 每行是一个字符串,表示待求的表达式,长度<=1000

输出

【标准输出】 对于每个表达式,输出一行,表示对应表达式的值。

样例输入

3

12+2*3

12*(2+3)

12*(2+3)+Smax(333,220+280)

样例输出

18

60

69

分析:

跟普通的表达式求值得算法没有什么大的区别,也是把中缀表达式转换为后缀表达式,然后用后缀表达式来求解。吧Smax也看做一种与加减乘除一样的运算,而他的优先级是最大的。

代码:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. char in[1001];///中缀
  4. char post[1001];///后缀
  5. int pri[200];///优先级
  6. bool isNum(char a)///判断是不是数字
  7. {
  8. if(a>='0'&&a<='9')
  9. return true;
  10. return false;
  11. }
  12. void zhuan()///中缀转后缀
  13. {
  14. stack<char>op;
  15. op.push('=');
  16. int k=0,k1=0;
  17. for(int i=0; in[i]!='\0'; i++)
  18. {
  19. if(in[i]=='m'||in[i]=='a'||in[i]=='x')///'S'也当作一个运算符了,这样的话就不用处理他们了
  20. continue;
  21. if(isNum(in[i]))
  22. {
  23. post[k++]=in[i];
  24. k1++;
  25. }
  26. else
  27. {
  28. if(k1!=0)///有数字的话,就把数字分割开
  29. {
  30. post[k++]=' ';
  31. k1=0;
  32. }
  33. if(in[i]==',')continue;///跳过,不用处理
  34. if(in[i]=='(')
  35. op.push(in[i]);
  36. else if(in[i]==')')
  37. {
  38. while(op.top()!='(')
  39. {
  40. post[k++]=op.top();
  41. op.pop();
  42. }
  43. op.pop();
  44. }
  45. else
  46. {
  47. while(pri[op.top()]>=pri[in[i]])
  48. {
  49. post[k++]=op.top();
  50. op.pop();
  51. }
  52. op.push(in[i]);
  53. }
  54. }
  55. }
  56. while(op.top()!='=')
  57. {
  58. post[k++]=op.top();
  59. op.pop();
  60. }
  61. post[k]='\0';
  62. }
  63. int Smax(int a,int b)///定义Smax的运算
  64. {
  65. int suma=0;
  66. while(a)
  67. {
  68. suma+=a%10;
  69. a/=10;
  70. }
  71. int sumb=0;
  72. while(b)
  73. {
  74. sumb+=b%10;
  75. b/=10;
  76. }
  77. return max(suma,sumb);
  78. }
  79. int result(int a,int b,char op)
  80. {
  81. switch(op)
  82. {
  83. case '+' :
  84. return a+b;
  85. case '-' :
  86. return b-a;
  87. case '*' :
  88. return a*b;
  89. case '/' :
  90. return b/a;
  91. case 'S' :
  92. return Smax(a,b);
  93. }
  94. }
  95. int jisuan()
  96. {
  97. stack<int>num;
  98. int sum=0;
  99. for(int i=0; post[i]; i++)
  100. {
  101. if(isNum(post[i]))
  102. sum=sum*10+post[i]-'0';
  103. else
  104. {
  105. if(sum!=0)
  106. {
  107. num.push(sum);
  108. sum=0;
  109. }
  110. if(post[i]!=' ')
  111. {
  112. int a=num.top();
  113. num.pop();
  114. int b=num.top();
  115. num.pop();
  116. num.push(result(a,b,post[i]));
  117. }
  118. }
  119. }
  120. return num.top();
  121. }
  122. int main()
  123. {
  124. // freopen("2.txt","r",stdin);
  125. ///定义优先级,'S'表示的是Smax这个算法,优先级最大
  126. pri['=']=0;
  127. pri['(']=1;
  128. pri['+']=2;
  129. pri['-']=2;
  130. pri['*']=3;
  131. pri['/']=3;
  132. pri['S']=4;
  133. int t;
  134. scanf("%d",&t);
  135. while(t--)
  136. {
  137. memset(in,0,sizeof(in));
  138. memset(post,0,sizeof(post));
  139. scanf(" %s",in);
  140. zhuan();
  141. //puts(post);
  142. printf("%d\n",jisuan());
  143. }
  144. return 0;
  145. }

NYOJ 1272 表达式求值 第九届省赛 (字符串处理)的更多相关文章

  1. NYOJ 35 表达式求值(逆波兰式求值)

    http://acm.nyist.net/JudgeOnline/problemset.php?typeid=4 NYOJ 35 表达式求值(逆波兰式求值) 逆波兰式式也称后缀表达式. 一般的表达式求 ...

  2. nyoj 305 表达式求值 (递归)

    表达式求值 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min ...

  3. NYOJ 305 表达式求值 (字符串处理)

    题目链接 描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min(20,23)的值是20 ,add(10,98) 的值是108等等.经过训练, ...

  4. NYOJ 35 表达式求值 (字符串处理)

    题目链接 描述 ACM队的mdd想做一个计算器,但是,他要做的不仅仅是一计算一个A+B的计算器,他想实现随便输入一个表达式都能求出它的值的计算器,现在请你帮助他来实现这个计算器吧. 比如输入:&quo ...

  5. nyoj(表达式求值)

    描述 ACM队的mdd想做一个计算器,但是,他要做的不仅仅是一计算一个A+B的计算器,他想实现随便输入一个表达式都能求出它的值的计算器,现在请你帮助他来实现这个计算器吧. 比如输入:"1+2 ...

  6. NYOJ 35 表达式求值

    一个模板了 哈哈. 这题由于已经包括了整形.浮点形了,以后也不须要特别处理了. /* 这里主要是逆波兰式的实现,使用两个stack 这里用字符串来模拟一个stack,第一步,将中缀表达式转变为后缀表达 ...

  7. NYOJ - 35 表达式求值 分类: NYOJ 2015-03-18 10:33 31人阅读 评论(0) 收藏

    #include<iostream> #include<string> #include<stack> #include<cstdio> using n ...

  8. 河南省acm第九届省赛--《表达式求值》--栈和后缀表达式的变形--手速题

    表达式求值 时间限制:1000 ms | 内存限制:65535 KB 难度:3   描述 假设表达式定义为:1. 一个十进制的正整数 X 是一个表达式.2. 如果 X 和 Y 是 表达式,则 X+Y, ...

  9. 数据结构--栈的应用(表达式求值 nyoj 35)

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=35 题目: 表达式求值 时间限制:3000 ms | 内存限制:65535 KB描述 AC ...

随机推荐

  1. 补发9.26“天天向上”团队Scrum站立会议

    组长:王森 组员:张金生 张政 栾骄阳 时间:2016.09.26 地点:612寝 组员 已完成 未完成 王森 可行性分析 找出设计亮点 张金生 寻找UI素材 设计用户操作 张政 搭建环境 基础逻辑框 ...

  2. PHP中类和对象

    面向对象中的基本概念 类和对象 对象:  万物皆对象: 类: 任何对象,都可以人为“规定”为某种类型(类别): class  Person{ var  $name ; var  $age; var   ...

  3. Mysql中关键词执行顺序

    MySQL的语句执行顺序 MySQL的语句一共分为11步,最先执行的总是FROM操作,最后执行的是LIMIT操作.其中每一个操作都会产生一张虚拟的表,这个虚拟的表作为一个处理的输入,只是这些虚拟的表对 ...

  4. (转自大富翁)LockType 属性

    指示编辑过程中对记录使用的锁定类型. 设置和返回值 设置或返回以下某个 LockTypeEnum 的值. 常量 说明 adLockReadOnly 默认值,只读.无法更改数据. adLockPessi ...

  5. 【.Net】在WinForm中选择本地文件

    相信很多朋友在日常的编程中总会遇到各钟各样的问题,关于在WinForm中选择本地文件就是很多朋友们都认为很难的一个学习.net的难点, 在WebForm中提供了FileUpload控件来供我们选择本地 ...

  6. MethodHandle

    JDK7为间接调用方法引入新的API,在java.lang.invoke包下,可以看作为反射的升级版,但它不像反射API那样显得冗长.繁重 主要的类 MethodHandle 方法句柄.对可直接执行的 ...

  7. Python 3中的str和bytes类型

    Python3 中的str和bytes类型 Python3最重要的新特性之一是:对字符串和二进制数据流做了明确的区分.文本总是Unicode,由str类型表示,二进制数据则由bytes类型表示.Pyt ...

  8. C++解析(18):C++标准库与字符串类

    0.目录 1.C++标准库 2.字符串类 3.数组操作符的重载 4.小结 1.C++标准库 有趣的重载--操作符 << 的原生意义是按位左移,例:1 << 2;,其意义是将整数 ...

  9. WordPress忘记密码找回登录密码的四种行之有效的方法

    WordPress忘记密码找回登录密码的四种行之有效的方法 PS:20170214更新,感谢SuperDoge同学提供的方法,登入phpMyAdmin后,先从左边选自己的数据库,然后点上面的 SQL ...

  10. NOI2018前的每日记录

    NOI2018前的每日记录 开头 今天是\(2018.7.2\),不知不觉已经这么久了.本来还是高一的小蒟蒻,过不了多久就要成为高二的老年选手了. 再过半个月我也要去\(NOI\)打酱油了.我这种D类 ...