C——简单计算器

题目:

读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值。

Input测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整数和运算符之间用一个空格分隔。没有非法表达式。当一行中只有0时输入结束,相应的结果不要输出。 
Output对每个测试用例输出1行,即该表达式的值,精确到小数点后2位。 
Sample Input

1 + 2
4 + 2 * 5 - 7 / 11
0

Sample Output

3.00
13.36

解题思路:虽然用数组也可以解决这一类题,但在这里我使用栈来解答这一题。显然这是一个模拟题。首先把数字和符号分别放入栈中;计算部分首先计算乘除法,并把计算的结果放入栈内,如果遇到加减号则把数字和符号分别放入另一个栈中此时另一个栈中就只有加减法,再计算加减法,得到计算结果。(注意计算顺序)
 1 #include <iostream>
 2 #include<stack>
 3 #include<queue>
 4 #include<cstring>
 5 #include<cstdio>
 6 using namespace std;
 7
 8 int main()
 9 {
10     int i,j,h,g=0,d,b,q;
11     double ans,x1,x2,k;
12     char a[202];
13     while (1)
14     {
15         memset(a,0,sizeof(a));
16         k=0;h=0;ans=0;d=0,b=0;g=0;
17         gets(a);
18         if (strlen(a)==1&&a[0]==‘0‘)break;
19         stack<char>f,f2;
20         stack<double>s,s2;
21         queue<char>f1;
22         queue<double>s1;
23         for (i=0;i<strlen(a);i++)
24         {
25         if (a[i]==‘ ‘){h++;continue;}  //分离数字和符号
26         else
27            {
28         if (h%2!=0){f.push(a[i]);s.push(k);k=0;d++;continue;}
29         if (h%2==0){k=k*10+(a[i]-‘0‘);}
30            }
31         }
32         s2.push(k);
33         q=d;
34         while (q--)        //导入另一个栈内使计算顺序正确(栈是后进先出)
35         {
36             s2.push(s.top());s.pop();
37             f2.push(f.top());f.pop();
38         }
39        while (d--)
40        {
41            g=1;
42            if (f2.top()==‘+‘||f2.top()==‘-‘)  //把加减法放入另一个队列
43            {
44                f1.push(f2.top());
45                s1.push(s2.top());
46                f2.pop();
47                s2.pop();
48                b++;continue;
49            }
50            if (f2.top()==‘*‘)      //计算乘除法
51            {
52                x1=s2.top();s2.pop();
53                x2=s2.top();s2.pop();
54                s2.push(x1*x2);
55                f2.pop();continue;
56            }
57            if (f2.top()==‘/‘)
58            {
59                x1=s2.top();s2.pop();
60                x2=s2.top();s2.pop();
61                s2.push(x1/x2);
62                f2.pop();continue;
63            }
64        }
65        s1.push(s2.top());
66        ans+=s1.front();s1.pop();
67        while (b--)
68        {
69            if (f1.front()==‘+‘)     //计算加减法
70            {
71                ans+=s1.front();
72                s1.pop();
73                f1.pop();continue;
74            }
75            if (f1.front()==‘-‘)
76            {
77                ans-=s1.front();
78                s1.pop();
79                f1.pop();continue;
80            }
81        }
82         if (g==1)printf("%0.2lf\n",ans);   //g==1用来控制格式(可以去掉)
83     }
84     return 0;
85 }
				
时间: 2024-08-08 19:10:06

C——简单计算器的相关文章

j2ee-JSP之简单计算器

来源韩顺平.j2ee视频实战教程jsp第1讲(下集) -------------------------------------------------------------------------------------------------------- 简单计算器,可以控制输入的数(仅第一个数)不能为空且不能为字符串 myCal.jsp代码 1 <!--这是计算器的界面 --> 2 <!-- 可以控制输入的数不能为空且不能为字符串 --> 3 <%@ page co

JAVA编写的简单计算器

package com.hellojava.practice.test; import java.awt.BorderLayout; import java.awt.GridLayout; import java.awt.Panel; import java.awt.TextField; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.JButton; impo

HDU1237 简单计算器 【栈】+【逆波兰式】

版本:1.0 日期:2014.5.17 2014.6.1 版权:© 2014 kince 转载注明出处 在介绍SwitchButton之前,先来看一下系统Button是如何实现的.源码如下: @RemoteView public class Button extends TextView { public Button(Context context) { this(context, null); } public Button(Context context, AttributeSet att

[Java.web]简单计算器

项目的  WebRoot 目录下的 calculator.jsp <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML> <html> <head> <title>计算结果</title> </head> <body> <jsp:us

NOIP19:简单计算器

/* 1.4编程基础之逻辑表达式与条件分支 19:简单计算器 总时间限制: 1000ms 内存限制: 65536kB 描述 一个最简单的计算器,支持+, -, *, / 四种运算.仅需考虑输入输出为整数的情况,数据和运算结果不会超过int表示的范围. 输入 输入只有一行,共有三个参数,其中第1.2个参数为整数,第3个参数为操作符(+,-,*,/). 输出 输出只有一行,一个整数,为运算结果.然而: 1. 如果出现除数为0的情况,则输出:Divided by zero! 2. 如果出现无效的操作符

hdoj 1237 简单计算器

简单计算器 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 14512    Accepted Submission(s): 4920 Problem Description 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值. Input 测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整

Shell 实现简单计算器功能

Shell 实现简单计算器功能,脚本如下: [[email protected] scripts]# cat jisuan.sh #!/bin/bash print_usage(){     printf $"USAGE:$0 NUM1 {+|-|*|/} NUM2\n"     exit 1 } #判断传入的参数是不是3个 if [ $# -ne 3 ]   then     print_usage fi firstnum=$1 secondnum=$3 op=$2 #对传入的参数进

Javascript 实现简单计算器实例代码

Javascript 实现简单计算器实例代码 这篇文章主要介绍了Javascript 实现简单计算器实例代码的相关资料,需要的朋友可以参考下 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63

菜鸟学Android编程——简单计算器《一》

菜鸟瞎搞,高手莫进 本人菜鸟一枚,最近在学Android编程,网上看了一些视频教程,于是想着平时手机上的计算器应该很简单,自己何不尝试着做一个呢? 于是就冒冒失失的开撸了. 简单计算器嘛,功能当然很少,加减乘除就可以. 第一步:设计布局文件 界面如下图: 由于刚开始学Android,对布局文件也不是很了解,边查边找,最后凑合着写好了布局文件. 注意事项:此布局文件用到了GridLayout布局,是在Android4.0以上才出现的(不知道谷歌有没有开发相应的包来适配4.0以下版本). 有关Gri

HDU 1237 简单计算器

简单计算器 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 12832    Accepted Submission(s): 4222 Problem Description 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值. Input 测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整