QQ登录

只需一步,快速开始

搜索
【活动】边做笔记边学习,还能赢取奖学金!
查看: 131|回复: 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. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:144 天
连续签到:17 天
最佳答案
120 
发表于 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. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋手机版Archiver( 粤公网安备 44051102000370号 | 粤ICP备11014136号

© 2010-2017 FishC.com GMT+8, 2017-7-22 10:44 Powered by Discuz! X2.5 Theme by dreambred

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