鱼C论坛

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

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

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

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

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

x
#include <stdio.h>
#include <stdlib.h>
typedef char SElemType ;
typedef struct StackNode
{
 SElemType data;
 struct StackNode *next;
}StackNode,*LinkStackPtr;
typedef struct LinkStack
{
 LinkStackPtr top;
 int count;
}LinkStack;
//栈指针初始化
void InitialStack(LinkStack *L)
{
 L->top=NULL;
 L->count=0;
 return;
}
//栈状态
int StackEmpty(LinkStack *pS)
{
 if(!pS->count)//若为空,则返回1
  return 1;
 else
  return 0;//若非空,则返回0;
}
//压栈操作
int Push(LinkStack *pS,SElemType e)
{
 //一般情况下,不存在栈满情况
 LinkStackPtr s=(LinkStackPtr)malloc(sizeof(StackNode));
 s->data = e;
 s->next = pS->top;
 pS->top=s;
 pS->count++;
 //free(s);
 return 0;
}
//出栈操作
int Pop(LinkStack *pS,SElemType *e)
{
 LinkStackPtr p;
 if(StackEmpty(pS))
  {
   printf("栈为空!");
      return 0;
     }
 *e=pS->top->data;
 p = pS->top;
 pS->top = p->next;
 free(p);
 pS->count--;
 return 0;
}
//打印栈链
void PrintStackLink(LinkStack *pS)
{
 LinkStackPtr L;
 int i;
 //i = pS->count;
 L = pS->top;
 if(pS->count == 0)
 {
  printf("栈为空!");
  return;
 }
 for(i=0;i<(pS->count);i++)
 {
  printf("%c\n",L->data);
     L = L->next;
 }
 return ;
}
void main()
{
 //测试
 char getch;
 char outch;
 LinkStack myStack;
 InitialStack(&myStack);
 //压栈
 printf("请输入压入栈的数据(char型),输入#结束");
 scanf("%c",&getch);
 while(getch!='#')
 {
  Push(&myStack,getch);
  scanf("%c",&getch);
 }
 printf("栈链内容为:\n");
 PrintStackLink(&myStack);
 //出栈
 while(!StackEmpty(&myStack))
 {
  Pop(&myStack,&outch);
  printf("弹出内容为:%c\n",outch);
 }
 PrintStackLink(&myStack);
 
 return ;
}
想知道小甲鱼最近在做啥?请访问 -> 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-11-22 04:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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