数据结构 栈的建立及入栈出栈操作 C语言版

//链栈的建立及其出栈入栈操作
#include <cstdio>
#include <stdlib.h>
typedef int StackElementType ;
typedef struct SNode
{
    StackElementType data;
    struct SNode * next;
} LinkStackNode,* LinkStack;  //定义链表的结点,链表头

void InitStack (LinkStack *top)  //初始化链表
{
    *top=(LinkStack)malloc(sizeof(SNode));
    (*top)->next=NULL;
}

int PushStack (LinkStack top,StackElementType x) //链栈的进栈  头插法
{
 LinkStackNode *temp;
 temp=(LinkStackNode *)malloc(sizeof(LinkStackNode));
 if(temp==NULL) return 0;
 temp->data=x;
 temp->next=top->next;
 top->next=temp;
 return 1;
}

int PopStack(LinkStack top, StackElementType *x)  //链栈的出栈 从头上开始出
{
 LinkStackNode *temp;
 temp=top->next;
 if(temp==NULL)
  return 0;
 top->next=temp->next;
 *x=temp->data;
 free(temp);
 return 1;
}


int main()
{
   LinkStack  top;  //top为链栈

    InitStack(&top);//初始化链栈
    int num,n;

 printf("输入要输入链栈的数的个数及要输入的数\n");
 scanf("%d",&n);
 for(int i=1;i<=n;i++)
 {
  scanf("%d",&num);
  if(!PushStack(top,num)) printf("链栈满\n");
 }
 printf("输入的数据依次出链栈\n");
 while(PopStack(top,&num)) printf("%d ",num);

    return 0;
}
  • 6
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值