鱼C论坛

 找回密码
 立即注册
查看: 2578|回复: 2

[技术交流] 数据结构练习代码——链栈

[复制链接]
发表于 2013-10-9 11:38:14 | 显示全部楼层 |阅读模式

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

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

x

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. typedef char SElemType ;
  4. typedef struct StackNode
  5. {
  6. SElemType data;
  7. struct StackNode *next;
  8. }StackNode,*LinkStackPtr;
  9. typedef struct LinkStack
  10. {
  11. LinkStackPtr top;
  12. int count;
  13. }LinkStack;
  14. //栈指针初始化
  15. void InitialStack(LinkStack *L)
  16. {
  17. L->top=NULL;
  18. L->count=0;
  19. return;
  20. }
  21. //栈状态
  22. int StackEmpty(LinkStack *pS)
  23. {
  24. if(!pS->count)//若为空,则返回1
  25.   return 1;
  26. else
  27.   return 0;//若非空,则返回0;
  28. }
  29. //压栈操作
  30. int Push(LinkStack *pS,SElemType e)
  31. {
  32. //一般情况下,不存在栈满情况
  33. LinkStackPtr s=(LinkStackPtr)malloc(sizeof(StackNode));
  34. s->data = e;
  35. s->next = pS->top;
  36. pS->top=s;
  37. pS->count++;
  38. //free(s);
  39. return 0;
  40. }
  41. //出栈操作
  42. int Pop(LinkStack *pS,SElemType *e)
  43. {
  44. LinkStackPtr p;
  45. if(StackEmpty(pS))
  46.   {
  47.    printf("栈为空!");
  48.       return 0;
  49.      }
  50. *e=pS->top->data;
  51. p = pS->top;
  52. pS->top = p->next;
  53. free(p);
  54. pS->count--;
  55. return 0;
  56. }
  57. //打印栈链
  58. void PrintStackLink(LinkStack *pS)
  59. {
  60. LinkStackPtr L;
  61. int i;
  62. //i = pS->count;
  63. L = pS->top;
  64. if(pS->count == 0)
  65. {
  66.   printf("栈为空!");
  67.   return;
  68. }
  69. for(i=0;i<(pS->count);i++)
  70. {
  71.   printf("%c\n",L->data);
  72.      L = L->next;
  73. }
  74. return ;
  75. }
  76. void main()
  77. {
  78. //测试
  79. char getch;
  80. char outch;
  81. LinkStack myStack;
  82. InitialStack(&myStack);
  83. //压栈
  84. printf("请输入压入栈的数据(char型),输入#结束");
  85. scanf("%c",&getch);
  86. while(getch!='#')
  87. {
  88.   Push(&myStack,getch);
  89.   scanf("%c",&getch);
  90. }
  91. printf("栈链内容为:\n");
  92. PrintStackLink(&myStack);
  93. //出栈
  94. while(!StackEmpty(&myStack))
  95. {
  96.   Pop(&myStack,&outch);
  97.   printf("弹出内容为:%c\n",outch);
  98. }
  99. PrintStackLink(&myStack);

  100. return ;
  101. }
复制代码

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2013-10-9 23:20:28 | 显示全部楼层
帮顶,等大神解决
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-11-17 08:52:06 | 显示全部楼层
好文章转过来方便自己看。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-20 13:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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