C++实现简单计算器(补发)

本文介绍了使用C++实现一个基础计算器的过程,包括中缀表达式转后缀表达式、两个栈的操作以及设置运算符优先级。作者通过实例说明了如何通过栈技术处理加减乘除等运算。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录


前言

本来想用Qt做的计算器,但是自己的计算器基础不够扎实,Qt也是,那就先慢慢来吧!想用C++把计算器做出来,再结合Qt去做。

一、设计目标

利用C++实现计算器的基本操作,如加减乘除、平方、取余数、加括号等,输入等式输出结果。

例如:

二、代码实现

1.中缀转后缀(入栈操作)

实现计算器的核心思想是中缀转后缀,这里创建两个栈,一个存放数字,一个存放运算符,依次入栈。运算符栈中,通过栈内和栈外的的优先级比较判断谁先计算,把优先级高运算符的先计算存在数字栈栈顶中,依次循环下直到运算符栈为空,返回数字栈栈顶的值。

举个简单的例子:

第一步,数字和运算符依次入栈,*的运算优先级大于+的,所以不用等栈内先算,直接入栈即可。(如果顺序是*再到+,则应先算栈内,+号再入栈)直到检测到=号,如果运算符栈不为空则一直计算下去。

第二步,栈顶出栈,两数计算,计算结果进入数字栈顶中。

第三步,1和6和+号出栈,计算6+1=7,入数字栈,最后返回数字栈顶的值即为计算得到的值。

 

 入栈的函数代码:

double Stack(){
	stack<double>Num;stack<char>Ch;
	double num;char ch;
	while(1){
		if(cin.peek()>='0'&&cin.peek()<='9'){
			cin>>num;
		    Num.push(num); 
	    }
	    else{
	    	cin>>ch;
	    	if(ch=='='){
	    		while(!Ch.empty()) calculate(Ch,Num);
	    		return Num.top();
			}
			else if(Ch.empty()||ch=='(') Ch.push(ch);
			else if(!Ch.empty()&&ch==')'){
				while(Ch.top()!='(')
				calculate(Ch,Num);
				Ch.pop();//左括号出栈 
			}
			else if(operate(Ch.top())>=operate(ch)){
				while(Ch.top()!='('){
					calculate(Ch,Num);
					if(Ch.empty()||operate(Ch.top())<operate(ch))
					break;
				}
				Ch.push(ch); 
			}
			else Ch.push(ch);
		}
	}
}

 这里有几个需要注意的点:

1.while(1)是无限循环,需要一个出口,这个出口即当检测到=号的时候。

2.这个判断主要是第一个输入的可能是数字可能是左括号,需要分情况讨论。

		if(cin.peek()>='0'&&cin.peek()<='9'){
			cin>>num;
		    Num.push(num); 
	    }

3.优先级的判断如果没有左括号的while,那么有些带括号的计算结果会报错。

2.两个栈的计算

栈的出栈和入栈计算什么的图已经分析了,下面给出代码:

void calculate(stack<char>&Ch,stack<double>&Num){
	double a=Num.top();Num.pop();
	double b=Num.top();Num.pop();
	if(Ch.top()=='+') Num.push(b+a);
	else if(Ch.top()=='-') Num.push(b-a);
	else if(Ch.top()=='*') Num.push(b*a);
	else if(Ch.top()=='/') Num.push(b/a);
	else if(Ch.top()=='^') Num.push(pow(b,a));
	else if(Ch.top()=='%') Num.push(int(b)%int(a));
	Ch.pop();
}

3.优先级的设置

int operate(char ch){
	if(ch=='(') return 0;
	else if(ch=='+'||ch=='-') return 1;
	else if(ch=='*'||ch=='/'||ch=='%') return 2;
	else if(ch=='^') return 3;
}

总结

个人的算法编程能力方面太菜了,今天开始要好好刷力扣的题目了。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Rubber树

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值