http://acm.hdu.edu.cn/showproblem.php?pid=1237

简单的栈的运用。

首先将数字和运算符分离,分别保存在两个数组中,然后按原来的式子的顺序,首先将第一个数和第一个运算符分别压

如个自的栈,然后判取出两个栈头部的元素,判断符号,如果是乘除就用当前数值乘取出的数字(优先),然后将乘后的数压入栈,

如果是加则将数和取出的数按原序入栈,如果减,就把新的数变负,将数和取出的数按原序入栈。

最后栈中所有元素的和就是结果。

 1 #include<stdio.h>
2 #include<algorithm>
3 #include<stdlib.h>
4 #include<string.h>
5 #include<math.h>
6 #include<iostream>
7 #include<stack>
8 #include<queue>
9 using namespace std;
10 char a[300];
11 char b[300];
12 double c[300];
13 int main(void)
14 {
15 int n,i,j,k,p,q,l;
16 while(gets(a))
17 {
18 l=strlen(a);
19 if(l==1&&a[0]=='0')
20 {
21 break;
22 }
23 double ss=1;
24 double sum=0;
25 int yy=0;
26 for(i=l-1; i>=0; i--)//从后往前循环分离,这样取数比较容易。
27 {
28 if(a[i]<='9'&&a[i]>='0')
29 {
30 sum+=ss*(a[i]-'0');
31 ss*=10;
32 }
33 else if(a[i]==' ')
34 {
35 continue;
36 }
37 else if(a[i]=='+'||a[i]=='-'||a[i]=='*'||a[i]=='/')
38 {
39 c[yy++]=sum;
40 sum=0;
41 ss=1;
42 b[yy++]=a[i];
43 }
44 }
45 c[yy]=sum;
46 stack<double>que;//数栈
47 stack<char>que1;//字符栈
48 if(yy==0)//特判就一个元素直接输出
49 {
50 printf("%.2f",c[0]);
51 }
52 else
53 {
54 que.push(c[yy]);
55 que1.push(b[yy-1]);
56 for(i=yy-2; i>=0; i-=2)
57 {
58 char cc=que1.top();//栈顶元素出栈
59 que1.pop();
60 double m=que.top();//栈顶元素出栈
61 que.pop();
62 if(cc=='*')//判断类型
63 {
64 m*=c[i];
65 que.push(m);
66 }
67 else if(cc=='/')
68 {
69 m=1.0*m/c[i];
70 que.push(m);
71 }
72 else if(cc=='+')
73 {
74 que.push(m);//按原序入栈
75 que.push(c[i]);
76 }
77 else if(cc=='-')
78 {
79 que.push(m);//按原序入栈
80 que.push(0-c[i]);
81 }
82 que1.push(b[i-1]);
83
84 }
85 double pp=0;
86 while(!que.empty())//最后栈中元素的和
87 {
88 pp+=que.top();
89 que.pop();
90 }
91 printf("%.2f",pp);
92 }
93 printf("\n");
94 }
95 return 0;
96 }

hdu-1237简单计算器(栈的运用)的更多相关文章

  1. HDU 1237 简单计算器 栈

    额,题目是中文的,题意就不用说了= =都看懂喽.写个字符串先把这行计算式存进去,不过不能存一个算一个,因为考虑到乘除法比加减法优先的原则,如果是加号减号就先存着等待计算,如果是乘号除号就直接算出来值就 ...

  2. hdu 1237 简单计算器

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1237 简单计算器 Description 读入一个只包含 +, -, *, / 的非负整数计算表达式, ...

  3. hdu 1237 简单计算器(栈处理)

    简单计算器 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  4. HDU 1237 简单计算器(栈+stringstream)

    提供几份代码,这题的输入可以用stringsteam处理,先处理乘除后处理加减,正常思路,但是后面统计加减法的时候,对栈的运用错了,我用的时候相当于给它多加了几个括号就错了. 正确的简单解法就是,加法 ...

  5. hdu 1237 简单计算器 (表达式求值)【stack】

    <题目链接> 题目大意: 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值.  Input测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符, ...

  6. hiho #1332 : 简单计算器 栈+递归

    #1332 : 简单计算器 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 编写一个程序可以完成基本的带括号的四则运算.其中除法(/)是整除,并且在负数除法时向0取整.( ...

  7. hdoj 1237 简单计算器

    简单计算器 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  8. F - 简单计算器(栈)

    F - 简单计算器 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descripti ...

  9. HDU1237 简单计算器 栈

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1237 题目大意:读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值. 题目分 ...

随机推荐

  1. 27-Roman to Integer-Leetcode

    Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 t ...

  2. 表格合并单元格【c#】

    gridBranchInfo.DataSource = dtBranchViewList; gridBranchInfo.DataBind(); Random random = new Random( ...

  3. Hadoop【MR的分区、排序、分组】

    [toc] 一.分区 问题:按照条件将结果输出到不同文件中 自定义分区步骤 1.自定义继承Partitioner类,重写getPartition()方法 2.在job驱动Driver中设置自定义的Pa ...

  4. STL全特化与偏特化

    在泛型编程中,常常会使用一些非完全泛型的类模板,这就是特化. 如何理解全特化呢?如上图所示,第一个template class是空间配置器的类模板,第二个就是一个全特化的template class. ...

  5. mysql读写分离(proxySQL) lamp+proxysql+nfs

    先在主从节点安装mysql [root@master-mariadb ~]# yum install mariadb-server -y [root@slave-mariadb ~]# yum ins ...

  6. 动态规划系列(零)—— 动态规划(Dynamic Programming)总结

    动态规划三要素:重叠⼦问题.最优⼦结构.状态转移⽅程. 动态规划的三个需要明确的点就是「状态」「选择」和「base case」,对应着回溯算法中走过的「路径」,当前的「选择列表」和「结束条件」. 某种 ...

  7. 【C/C++】从矩阵左上角走到右下角

    tx的笔试,但是只过了10%,就离谱 #include <bits/stdc++.h> using namespace std; const int maxn = 1010; long d ...

  8. 关于为了一时方便,使用@Scheduled注解定时踩的坑

    摘要: 事情是这样的前两周在做项目的时候碰到一个需求---要求每天晚上执行一个任务,公司统一使用的是 xxl-job 写定时任务的,我当时为了方便自己,然后就简单的使用了Spring的那个@Sched ...

  9. MySQL数据库SUBSTRING_INDEX的运用

    一.如何运用SUBSTRING_INDEX截取address的省市区 二.应用SUBSTRING_INDEX函数进行多次嵌套截取 SELECT SUBSTRING_INDEX(t1.`address` ...

  10. heap exploit about ptmalloc in glibc version 2.31

    学习的一下高版本的libc的利用方式. 项目地址:https://github.com/StarCross-Tech/heap_exploit_2.31 tcache_dup 源代码: 1 #incl ...