简单计算器

本文介绍了一种将中缀表达式转换为后缀表达式的方法,并详细解释了转换规则及计算过程。通过使用栈和队列数据结构,可以有效地处理正整数的加减乘除运算,最终实现对后缀表达式的求值。

只能实现正整数的加减乘除

表达式为中缀(字符串),变后缀(队列)的规则:
1、从前到后取中缀表达式的字符。
2、如果是数字直接加入后缀队列。
3、如果是运算符:
若中缀表达式运算符优先级高于操作符栈顶元素优先级则压入栈中;
否则,弹栈直到栈空或栈顶元素优先级不高于中缀表达式运算符;
4、若中缀表达式还没有遍历完,重复2,3。
5、将运算符栈中剩余元素加入到后缀队列中。

#include <iostream>
#include <stack>
#include <map>
#include <queue>
using namespace std;
struct node{
    char c;
    double num;
    bool isNum;
};
map<char,int>oper;
void Change(string s,queue<node>&q){//中缀表达式变后缀表达式
    stack<node>op;
    for (int i = 0; i < s.length();) {
        node temp;
        temp.num=0;
        if(s[i]>='0'&&s[i]<='9'){
            temp.isNum=true;
            temp.num=s[i++]-'0';
            while(i<s.length()&&s[i]>='0'&&s[i]<='9')//数字可能不止一位
                temp.num=temp.num*10+(s[i++]-'0');
            q.push(temp);
        }else{
            temp.isNum=false;
            temp.c=s[i];
            while(!op.empty()&&oper[s[i]]<=oper[op.top().c]){
                q.push(op.top());
                op.pop();
            }
            op.push(temp);
            i++;
        }
    }
    while(!op.empty()){
        q.push(op.top());
        op.pop();
    }
};
double Cal(queue<node>q){//后缀表达式求值
    stack<node>s;
    node temp;
    while(!q.empty()){
        temp.num=0;
        if(q.front().isNum==true){
            s.push(q.front());
            q.pop();
        }
        else{
            double temp2=s.top().num;
            s.pop();
            double temp1=s.top().num;
            s.pop();
            if(q.front().c=='+')temp.num=temp1+temp2;
            else if(q.front().c=='-')temp.num=temp1-temp2;
            else if(q.front().c=='*')temp.num=temp1*temp2;
            else
                temp.num=temp1/temp2;
            q.pop();
            s.push(temp);
        }
    }
    return s.top().num;
}
int main(){
    oper['+']=oper['-']=1;
    oper['*']=oper['/']=2;
    queue<node>q;
    string exp;
    cin>>exp;
    for (string::iterator it=exp.end();it!=exp.begin();it--) {//去掉表达式中的空格
        if(*it==' ')exp.erase(it);
    }
    Change(exp,q);
    printf("%.2f\n",Cal(q));
    return 0;
}
package com.softeem.train.calculator; import java.util.Scanner; import java.io.*; public class Calculator { private int m; // 第一个输入的数字 private int n; // 第二个输入的数字 public Calculator() { this.m = 0; this.n = 0; } /* * public void use() { System.out.println("你是否继续使用?继续输入Y,退出输任意键?"); Scanner * in5= new Scanner(System.in); String zz=in5.next(); * if(zz.equals("Y")||zz.equals("y")) this.gui(); else System.exit(0); * * } */ public void graphic() { //3 System.out.println("=========================="); System.out.println("欢迎使用 So easy 计算机简易系统 "); System.out.println(" 请选择计算类型:"); System.out.println(" 1.加法"); System.out.println(" 2.减法"); System.out.println(" 3.乘法"); System.out.println(" 4.除法"); System.out.println(" 5.输入表达式计算"); System.out.println(" 6.退出"); System.out.println("=========================="); Scanner in3 = new Scanner(System.in); int n = in3.nextInt(); switch (n) { //4 case 1: this.add(); //8 break; case 2: this.sub(); break; case 3: this.mul(); break; case 4: this.div(); break; case 5: this.cal(); break; case 6: System.exit(0); default: break; } } public void add() // 实现加法的方法 { //5 System.out.println("欢迎使用加法操作"); this.in(); //7 int sum; sum = this.m + this.n; System.out.println("你输入的数据的和是:" + sum); // this.use(); } public void sub() // 实现减法的方法 { System.out.println("欢迎使用减法操作"); this.in(); int cha; cha = this.m - this.n; System.out.println("你输入的数据的差是:" + cha); // this.use(); } public void mul() // 实现乘法的方法 { System.out.println("欢迎使用乘法操作"); this.in(); int ji; ji = this.m * this.n; System.out.println("你输入的数据的积是:" + ji); // this.use(); } public void div() // 实现除法的方法 { System.out.println("欢迎使用除法操作"); this.in(); if (n == 0) { System.out.println("被除数不能为零!"); this.graphic(); } int shang; shang = this.m / this.n; System.out.println("你输入的数据的和是:" + shang); // this.use(); } public void cal() // 实现表达式运算方法 { String s = ""; // 接收表达式的字符串 String ss1 = ""; // 分离数字m的字符串 String ss2 = ""; // 分离数字n的字符串 char c1 = ' '; // 存放运算符 int m = 0; // 第一个数字 int n = 0; // 第二个数字 System.out.print("请输入一个表达式:"); try { BufferedReader in = new BufferedReader(new InputStreamReader( System.in)); s = in.readLine(); } catch (IOException e) { } for (int i = 0; i < s.length(); i++) { if ((s.charAt(i) == '+') || (s.charAt(i) == '-') || (s.charAt(i) == '*') || (s.charAt(i) == '/')) { c1 = s.charAt(i); // 第一个数 for (int j = 0; j < i; j++) { ss1 += s.charAt(j); m = Integer.parseInt(ss1); } // 第二个数 for (int j = i + 1; j < s.length(); j++) { ss2 += s.charAt(j); n = Integer.parseInt(ss2); } break; } } if (c1 == '+') System.out.println(m + "+" + n + "=" + (m + n)); if (c1 == '-') System.out.println(m + "-" + n + "=" + (m - n)); if (c1 == '*') System.out.println(m + "*" + n + "=" + (m * n)); if (c1 == '/') System.out.println(m + "/" + n + "=" + (m / n)); } public void in() // 实现接收数据的方法 { //6 System.out.println("请输入第一个数:"); Scanner in1 = new Scanner(System.in); this.m = in1.nextInt(); System.out.println("请输入第二个数:"); Scanner in2 = new Scanner(System.in); this.n = in2.nextInt(); } public static void main(String[] args) throws java.io.IOException { //1 String ifquit = ""; // 用于接收是否退出 Calculator c = new Calculator(); do { //2 c.graphic(); // 调用界面方法 //9 System.out.println("你是否继续使用?继续输入Y,退出输任意键?"); Scanner in5 = new Scanner(System.in); ifquit = in5.nextLine(); //10 } while (ifquit.equals("Y") || ifquit.equals("y")); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值