鱼C论坛

 找回密码
 立即注册
查看: 3091|回复: 7

[已解决]这个栈运行错误,没找出原因啊

[复制链接]
发表于 2016-3-29 20:14:25 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

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

x
  1. #include<stdio.h>
  2. #define DATA1 int
  3. #define MAXSIZE 100
  4. typedef struct
  5. {                //定义栈
  6.         DATA1 data[MAXSIZE];
  7.         int top;
  8. }SEQSTACK;

  9. void push(SEQSTACK *s,DATA1 x)
  10. {                //入栈
  11.         s->top=0;
  12.         s->top++;
  13.         (s->data)[s->top]=x;
  14. }

  15. void print_stack(SEQSTACK *s)
  16. {               //打印栈
  17.         int i;
  18.         for(i=0;i<=s->top;i++)
  19.                 printf("%d",s->data[i]);
  20. }
  21. main()
  22. {
  23.         SEQSTACK *s;
  24.     push(s,2);
  25.         print_stack(s);
  26. }
复制代码



刚刚学习,就是想测试下我的理解对不对,可是找不到哪里出毛病了。
刚刚学习,望多多关照。
最佳答案
2023-11-30 08:45:55
存在以下问题:

在main函数中,您声明了一个指向SEQSTACK结构体的指针s,但没有为其分配内存空间。在使用指针之前,需要分配内存,可以使用malloc函数进行动态内存分配。另外,由于s是指针类型,调用函数时应该传递指针的地址而不是指针本身。

在push函数中,每次调用push函数时,都将s->top设置为0,这会导致之前入栈的元素被覆盖。应该将s->top的初始化放在main函数中,在第一次调用push函数之前进行初始化。

在print_stack函数中,打印栈的循环条件应该是i < s->top,而不是i <= s->top。由于栈的初始状态是空的,s->top的初始值为-1,因此应该使用<进行判断。

参考代码:

  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define DATA1 int
  4. #define MAXSIZE 100

  5. typedef struct
  6. {
  7.     DATA1 data[MAXSIZE];
  8.     int top;
  9. } SEQSTACK;

  10. void push(SEQSTACK *s, DATA1 x)
  11. {
  12.     s->top++;
  13.     (s->data)[s->top] = x;
  14. }

  15. void print_stack(SEQSTACK *s)
  16. {
  17.     int i;
  18.     for (i = 0; i < s->top; i++)
  19.     {
  20.         printf("%d ", s->data[i]);
  21.     }
  22.     printf("\n");
  23. }

  24. int main()
  25. {
  26.     SEQSTACK *s = (SEQSTACK *)malloc(sizeof(SEQSTACK)); // 分配内存空间
  27.     s->top = -1; // 初始化栈顶指针

  28.     push(s, 2);
  29.     print_stack(s);

  30.     free(s); // 释放内存空间
  31.     return 0;
  32. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-3-30 07:35:20 | 显示全部楼层
没人啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-3-30 12:55:50 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-4-11 22:24:57 | 显示全部楼层
有好多错误哦,main()函数前边应该加类型,一般是int,最后return 0;还有push函数里边s->top=0,使得每次入栈都将栈顶改为0了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-4-11 22:27:12 | 显示全部楼层
还有就是print_stack,打印栈内数据应是从栈顶先出栈,你的循环是从0开始打印,不符合栈的特性
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-4-18 16:19:59 | 显示全部楼层
好了,通过自己的努力找到了。还得用malloc开辟新单元  谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-4-19 19:28:51 | 显示全部楼层
过来支持一下
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-30 08:45:55 | 显示全部楼层    本楼为最佳答案   
存在以下问题:

在main函数中,您声明了一个指向SEQSTACK结构体的指针s,但没有为其分配内存空间。在使用指针之前,需要分配内存,可以使用malloc函数进行动态内存分配。另外,由于s是指针类型,调用函数时应该传递指针的地址而不是指针本身。

在push函数中,每次调用push函数时,都将s->top设置为0,这会导致之前入栈的元素被覆盖。应该将s->top的初始化放在main函数中,在第一次调用push函数之前进行初始化。

在print_stack函数中,打印栈的循环条件应该是i < s->top,而不是i <= s->top。由于栈的初始状态是空的,s->top的初始值为-1,因此应该使用<进行判断。

参考代码:

  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. #define DATA1 int
  4. #define MAXSIZE 100

  5. typedef struct
  6. {
  7.     DATA1 data[MAXSIZE];
  8.     int top;
  9. } SEQSTACK;

  10. void push(SEQSTACK *s, DATA1 x)
  11. {
  12.     s->top++;
  13.     (s->data)[s->top] = x;
  14. }

  15. void print_stack(SEQSTACK *s)
  16. {
  17.     int i;
  18.     for (i = 0; i < s->top; i++)
  19.     {
  20.         printf("%d ", s->data[i]);
  21.     }
  22.     printf("\n");
  23. }

  24. int main()
  25. {
  26.     SEQSTACK *s = (SEQSTACK *)malloc(sizeof(SEQSTACK)); // 分配内存空间
  27.     s->top = -1; // 初始化栈顶指针

  28.     push(s, 2);
  29.     print_stack(s);

  30.     free(s); // 释放内存空间
  31.     return 0;
  32. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-29 01:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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