袁愈权


私信TA

用户名:dotcpp0787148

访问量:271

签 名:

原神玩家不会轻易认输!

等  级
排  名 534
经  验 4450
参赛次数 3
文章发表 53
年  龄 19
在职情况 学生
学  校 贺州学院
专  业 网络工程

  自我简介:

刷完这题就去玩原神

TA的其他文章

c++猜字游戏
浏览:28
高精度加法
浏览:14
高精度减法
浏览:20

解题思路:

注意事项:

参考代码:

#include"bits/stdc++.h"
using namespace std;
// 定义一个栈,用于存储操作数
stack<long long> st;
// 初始化变量sum, kk, hh
long long sum=0, kk, hh;
// 定义字符变量s
char s;
int main(){
    // 循环读取输入字符,直到遇到'@'结束
    while((s=getchar())!='@'){
        // 如果字符是数字
        if(s>='0'&&s<='9'){
            // 将字符转换为对应的数字并累加到sum中
            sum=sum*10+s-'0';
        }
        // 如果字符是空格
        else if(s==' '){
            // 将当前sum压入栈中
            st.push(sum);
            // 重置sum为0
            sum=0;
        }
        // 如果字符是运算符
        else{
            // 从栈顶弹出两个操作数
            kk=st.top();
            st.pop();
            hh=st.top();
            st.pop();
            // 根据运算符进行相应的运算
            if(s=='+'){
                // 将结果压入栈中
                st.push(hh+kk);
            }
            else if(s=='-'){
                // 将结果压入栈中
                st.push(hh-kk);
            }
            else if(s=='*'){
                // 将结果压入栈中
                st.push(hh*kk);
            }
            else{
                // 将结果压入栈中
                st.push(hh/kk);
            }
        }
    }
    // 输出栈顶元素,即最终计算结果
    cout<<st.top();
    return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »