鱼C论坛

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

栈链问题,看不出是哪里溢出了,求指点

[复制链接]
发表于 2014-11-8 18:18:25 | 显示全部楼层 |阅读模式
10鱼币
本帖最后由 漠水 于 2014-11-8 20:00 编辑

话说不知道是什么函数出问题了,看着感觉挺顺的啊
问题应该是删除函数del或者显示print这里,看不出来
  1. #include<stdio.h>
  2. #include<malloc.h>
  3. #include<stdlib.h>
  4. #define NULL 0
  5. typedef struct stack
  6. {
  7. stack *top;
  8. int n;
  9. }stack;

  10. stack *creat()
  11. {
  12. stack *p; //初始化栈顶为空
  13. p=(stack *)malloc(sizeof(stack));
  14. p->top=NULL;
  15. return p;
  16. }

  17. stack *insert(int n,stack *p) //这里返回值为p,指针类型为stack结构体,需要 stack *来表示
  18. {
  19. stack *q; //q为栈顶空间
  20. q=(stack *)malloc(sizeof(stack));
  21. q->top=p; //第一次q指向初始化空间p,而后都是q取代指向原来的栈顶位置,指向它
  22. q->n=n; //栈顶值输入
  23. p=q; //令指针指向栈顶
  24. return p;
  25. }

  26. stack *del(stack *p)
  27. {
  28. stack *q;
  29. if(p->top==NULL)printf("空栈无需删除\n");
  30. else
  31. {
  32. q=p->top; //栈指向下一个top值
  33. free(p);        //释放原来栈顶空间
  34. p=q;           //指针指向新的栈顶空间
  35. }
  36. return p;
  37. }


  38. void print(stack *p) //显示不能把p的值给直接搞没了
  39. {
  40. stack *q;
  41. q=p;
  42. if(q->top==NULL)printf("空栈\n");
  43. else
  44. { printf("***************\n");
  45. while(q->top!=NULL)
  46. {
  47. printf("\n%d\n",q->n);
  48. q=q->top;
  49. }
  50. printf("\n***************\n");
  51. }


  52. }


  53. void main()
  54. {
  55. stack *p;
  56. p=creat();
  57. p=insert(5,p);
  58. p=insert(4,p);
  59. print(p);
  60. del(p);
  61. print(p);
  62. }
复制代码

最佳答案

查看完整内容

把main函数里的del(p); 改为p = del(p); 因为del(p)将p所指向的内容所占用的空间释放了,引用释放了的空间会出错,应该让p指向删除栈顶后的下一项(新的栈顶)
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-11-8 18:18:26 | 显示全部楼层
把main函数里的del(p); 改为p = del(p);
因为del(p)将p所指向的内容所占用的空间释放了,引用释放了的空间会出错,应该让p指向删除栈顶后的下一项(新的栈顶)
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-11-8 19:14:37 | 显示全部楼层
main函数多加了一个print
这不已经删除了么?
del(p);
//print(p);

  1. #include<stdio.h>
  2. #include<malloc.h>
  3. #include<stdlib.h>
  4. #define NULL 0
  5. typedef struct stack
  6. {
  7. stack *top;
  8. int n;
  9. }stack;

  10. stack *creat()
  11. {
  12. stack *p; //初始化栈顶为空
  13. p=(stack *)malloc(sizeof(stack));
  14. p->top=NULL;
  15. return p;
  16. }

  17. stack *insert(int n,stack *p) //这里返回值为p,指针类型为stack结构体,需要 stack *来表示
  18. {
  19. stack *q; //q为栈顶空间
  20. q=(stack *)malloc(sizeof(stack));
  21. q->top=p; //第一次q指向初始化空间p,而后都是q取代指向原来的栈顶位置,指向它
  22. q->n=n; //栈顶值输入
  23. p=q; //令指针指向栈顶
  24. return p;
  25. }

  26. stack *del(stack *p)
  27. {
  28. stack *q;
  29. if(p->top==NULL)printf("空栈无需删除\n");
  30. else
  31. {
  32. q=p->top; //栈指向下一个top值
  33. free(p);
  34. p=q; //释放栈顶空间

  35. }
  36. return p;
  37. }


  38. void print(stack *p) //显示不能把p的值给直接搞没了
  39. {
  40. stack *q;
  41. q=p;
  42. if(q->top==NULL)printf("空栈\n");
  43. else
  44. {
  45.         printf("***************\n");
  46.         while(q->top!=NULL)
  47.         {
  48.                 printf("\n%d\n",q->n);
  49.                 q=q->top;
  50.         }
  51. printf("\n***************\n");
  52. }


  53. }


  54. void main()
  55. {
  56. stack *p;
  57. p=creat();
  58. p=insert(5,p);
  59. p=insert(4,p);
  60. print(p);
  61. del(p);
  62. //print(p);
  63. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2014-11-8 19:56:28 | 显示全部楼层
向往青莲 发表于 2014-11-8 19:14
main函数多加了一个print
这不已经删除了么?
del(p);

我这里的print函数的是显示,而del(p)相当于pop 函数,有出栈1个数字,而我插入了2个数字,按道理应该还剩下第二个输出数字5才对,不懂求解,谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2014-11-8 20:44:35 From FishC Mobile | 显示全部楼层
原来如此,是我忘记了,上次也是出现同样的问题,都是忘记了函数的返回值无法传递,需要重新赋值,谢谢了哈。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-11-30 11:27:39 | 显示全部楼层
学习学习
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

头像被屏蔽
发表于 2014-12-2 20:18:01 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-1-11 21:44:51 | 显示全部楼层
莫水同学解释得不错,还请楼主j将此题标志为已解决。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-8 00:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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