鱼C论坛

 找回密码
 立即注册
查看: 1450|回复: 5

[已解决]关于栈的输入输出

[复制链接]
发表于 2020-8-25 16:50:05 | 显示全部楼层 |阅读模式
30鱼币
跟着书本学习了栈,然后写好后发现输出不出来  不知道啥原因,大佬帮忙看看,输入了没输出

图片是输入格式 代码如下
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>

  4. int top,S[1000];

  5. void push(int x)
  6. {
  7.         S[++top]=x;
  8. }

  9. int pop()
  10. {
  11.         top--;
  12.         return S[top+1];
  13. }

  14. int main()
  15. {
  16.         int a,b;
  17.         top=0;
  18.         char s[100];
  19.        
  20.         while(scanf("%d",s)!=EOF)
  21.         {
  22.                 if(s[0]=='+')
  23.                 {
  24.                         a=pop();
  25.                         b=pop();
  26.                         push(a+b);
  27.                 }
  28.                 else if(s[0]=='*')
  29.                 {
  30.                         a=pop();
  31.                         b=pop();
  32.                         push(a*b);
  33.                 }
  34.                 else
  35.                 {
  36.                         push(atoi(s));
  37.                 }
  38.         }
  39.        
  40.         printf("%d\n",pop());
  41.        
  42.         return 0;
  43. }
复制代码


麻烦啦!谢谢大佬们!
最佳答案
2020-8-25 16:50:06
1、这个栈有点问题把,函数是传值的,数组push,pop两个函数会被改变没问题,但是top可不会啊。top从两个函数出来一直是0。栈要用结构体,到时候压栈,出栈函数参数用结构体指针。
2、然后主函数里的scanf,用%d输入的话全是数字了哪还有运算符,还有不少问题a,b又是什么这类。
解决这个问题的思路是,有一个栈,然后输入一串字符,然后循环判断,有数字型字符的话转换成十进制数字入栈,有运算符的话先把被操作数和操作数弹出来,再用swith语句判断运算符类型,把结果入栈。
QQ浏览器截图20200825164914.png

最佳答案

查看完整内容

1、这个栈有点问题把,函数是传值的,数组push,pop两个函数会被改变没问题,但是top可不会啊。top从两个函数出来一直是0。栈要用结构体,到时候压栈,出栈函数参数用结构体指针。 2、然后主函数里的scanf,用%d输入的话全是数字了哪还有运算符,还有不少问题a,b又是什么这类。 解决这个问题的思路是,有一个栈,然后输入一串字符,然后循环判断,有数字型字符的话转换成十进制数字入栈,有运算符的话先把被操作数和操作数弹出 ...
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-8-25 16:50:06 | 显示全部楼层    本楼为最佳答案   
1、这个栈有点问题把,函数是传值的,数组push,pop两个函数会被改变没问题,但是top可不会啊。top从两个函数出来一直是0。栈要用结构体,到时候压栈,出栈函数参数用结构体指针。
2、然后主函数里的scanf,用%d输入的话全是数字了哪还有运算符,还有不少问题a,b又是什么这类。
解决这个问题的思路是,有一个栈,然后输入一串字符,然后循环判断,有数字型字符的话转换成十进制数字入栈,有运算符的话先把被操作数和操作数弹出来,再用swith语句判断运算符类型,把结果入栈。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-8-25 17:17:22 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-8-25 17:30:37 | 显示全部楼层
数据处理太麻烦了!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-8-25 17:32:37 | 显示全部楼层
逆波兰表达式
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-8-25 17:44:56 | 显示全部楼层
xiaozhangxuexi 发表于 2020-8-25 17:41
1、这个栈有点问题把,函数是传值的,数组push,pop两个函数会被改变没问题,但是top可不会啊。top从两个函 ...

谢谢!明白了  还是自己不够仔细!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-15 09:43

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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