L2-033 简单计算器 (25 point(s))

该程序实现了将中缀表达式转换为计算结果。通过读取输入的整数和运算符,利用栈来处理加减乘除操作,遇到除法时检查除数是否为0以避免错误。最终得出计算结果。

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

/*
*@author: percation
*#time:2021.04.22
*/
#include <bits/stdc++.h>
using namespace std;

int main(){
	int n;
	cin >> n;
	stack<int> st;
	stack<char> op;
	int num;
	char c;
	for(int i = 0; i < n; i++){
		cin >> num;
		st.push(num);
	}
	for(int i = 0; i < n - 1; i++){
		cin >> c;
		op.push(c); 
	} 
	int ans = 0;
	char oop;
	while(!op.empty() || st.size() != 1){
		int a = st.top();//n1
		st.pop();
		int b = st.top();//n2;
		st.pop();
		if(!op.empty()){
			oop = op.top();
			op.pop();
		}
		if(oop == '+'){
			ans = b + a;
			st.push(ans);
		} 
		if(oop == '-'){
			ans = b - a;
			st.push(ans);
		}
		if(oop == '*'){
			ans = b * a;
			st.push(ans);
		} 
		if(oop == '/'){
			if(a != 0){
				ans = b / a;
				st.push(ans);
			}
			else{
				cout << "ERROR: " << b <<"/0" << endl;
				return 0;
			}
		}
	}
	cout << st.top() << endl;

	return 0;
} 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值