QQ登录

只需一步,快速开始

登录 | 立即注册 | 找回密码
查看: 222|回复: 2

逆波兰求结果出现错误

[复制链接]
最佳答案
0 

尚未签到

发表于 2017-7-9 16:44:23 | 显示全部楼层 |阅读模式

马上注册加入鱼C,享用更多服务吧^_^

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
void CaluateStack(STACK S,ElemType *answer)                //STACK Sstack储存有逆波兰后续表达式
{
        STACK p1;                                                                //p1储存逆波兰的数值
        ElemType temp1,temp2;               
        int i=0;
        InitStack(&p1);   
        while(S.stack[i] != '\0')
        {
                *answer=S.stack[i];
                switch(*answer)
                {
                        case '+':
                                pop(&p1,&temp1);
                                pop(&p1,&temp2);
                                push(&p1,(temp1-'0')+(temp2-'0'));
                                break;
                        case '-':
                                pop(&p1,&temp1);
                                pop(&p1,&temp2);
                                push(&p1,(temp2-'0')-(temp1-'0'));
                                break;
                        case '*':
                                pop(&p1,&temp1);
                                pop(&p1,&temp2);
                                push(&p1,(temp2-'0')*(temp1-'0'));
                                break;
                        case '/':
                                pop(&p1,&temp1);
                                pop(&p1,&temp2);
                                if(temp1 == '0')
                                        printf("errror");
                                else
                                        push(&p1,(temp2-'0')/(temp1-'0'));
                                break;
                        default:
                                push(&p1,*answer);
                }
                i++;
        }
        printf("%d",p1.stack[0]);
}

能算两位数加减乘除,三位以上算不了
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
最佳答案
275 
累计签到:258 天
连续签到:5 天
发表于 2017-7-10 07:44:47 | 显示全部楼层
http://www.so.com/link?m=a3Xbu%2B%2FxB5KbziQAUugg0NuWGHdPIFvmb8e3%2By%2FY9aHYOTFHBckY%2FwbHzSWVSFydug5gBgZarQRQbwlj7nJzylEagF%2FHaPMLj9oHVJ3ooXWBV%2BorohuQMw8hhtGJCRyM7ucfNB1KkF3X5tozHAnayQ5yjDJUY6MeFqqgi7YnPRl5%2BfWJgfHXdhA%3D%3D
恩你的代码真简洁~
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
最佳答案
0 

尚未签到

 楼主| 发表于 2017-7-10 10:38:26 | 显示全部楼层
新手·ing 发表于 2017-7-10 07:44
http://www.so.com/link?m=a3Xbu%2B%2FxB5KbziQAUugg0NuWGHdPIFvmb8e3%2By%2FY9aHYOTFHBckY%2FwbHzSWVSFydu ...

还有的压栈,出栈,初始没复制过来
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

小甲鱼强烈推荐 上一条 /3 下一条

    移动客户端下载(未启用)
    微信公众号

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备11014136号

Copyright 2018 鱼C论坛 版权所有 All Rights Reserved.

Powered by Discuz! X3.1 Copyright
© 2001-2018 Comsenz Inc.    All Rights Reserved.

小黑屋|手机版|Archiver|鱼C工作室 ( 粤公网安备 44051102000370号 | 粤ICP备11014136号

GMT+8, 2017-11-19 07:02

快速回复 返回顶部 返回列表