潘潘在此无敌 2021-09-11 09:45 采纳率: 100%
浏览 1513
已结题

c++ 简易计算器 back() called on empty deque 问题错误

#include<iostream>
#include<string>
#include<stack>
#include<cmath>
using namespace std;

class jisuanqi
{
private:
    string a;
    stack <int>s;
    stack<char>f;
public:
    jisuanqi()
    {
        a = "3+2*(5+1)=";
    }
    void jisuan();
    int youxianji(char a);
    int suan(char a,int xia,int shang);
};
int jisuanqi::suan(char a,int xia,int shang)
{
    switch (a)
    {
    case '+':return xia + shang;
    case '-':return xia - shang;
    case '/':return xia / shang;
    case '*': return xia * shang;
    }
}
int jisuanqi::youxianji(char a)
{
    switch (a)
    {
    case ')': return 0;
        break;
    case '+':return 1;
        break;
    case '-':return 1;
        break;
    case '*':return 2;
        break;
    case '/':return 2;
        break;
    case '(':return 3;
        break;
    default:
        return -1000;
        cout << "符号输入错误";
    }
}
void jisuanqi::jisuan()
{
    char* b = &a[0];

    while (*b != '=')
    {
        int num = 0;
        int k = 0;
        if (*b >= '0' && *b <='9')
        {
            char* c = (b + 1);
            while (*c <= '9' && *c>='0')
            {
                num++;
                c = (c + 1);
            }
            while (num != 0)
            {
                k = k + (int(*b)-48) * pow(10, num);
                num--;
                b++;
            }
            s.push(k + int(*b)-48);
            b++;

        }
        else
        {
            if(f.top()=='(')
            {
                f.push(*b);
                b++;
                continue;
            }
            if(f.top()=='('&&*b==')')
            {
                f.pop();
                b++;
                continue;
            }
            if (f.empty())
            {
                f.push(*b);
                b++;
                continue;
            }
            else if (!f.empty()&&youxianji(f.top() )>= youxianji(*b))
            {
                int t = s.top();
                s.pop();
                int r = s.top();
                s.pop();
                s.push(suan(f.top(), r, t));
                f.pop();
            }
            else if (!f.empty()&&youxianji(f.top()) < youxianji(*b))
            {
                f.push(*b);
            }
            b++;
        }
    
    }
    while(!f.empty()&&!s.empty())
    {
        int q = s.top();
        s.pop();
        int z = s.top();
        s.pop();
        s.push(suan(f.top(), z, q));
        f.pop();
    }
    cout << s.top();
    return;
}

int main()
{
    jisuanqi x;
    x.jisuan();
    system("pause");
    return 0;
}

img

img

简易计算器,请问,错误大概是什么类型的?如何解决?

  • 写回答

1条回答 默认 最新

  • 关注

    可能是因为一开始栈为空,此时调用top函数会报错
    有帮助望采纳

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月19日
  • 已采纳回答 9月11日
  • 修改了问题 9月11日
  • 修改了问题 9月11日
  • 展开全部

悬赏问题

  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看