C语言实现基本数据结构之栈

#include <stdio.h>
#include <stdlib.h>
//定义一个栈
typedef struct anode{
           int data;
           struct node* next,*pro;
}node;
typedef struct astack{
           struct anode *bottom,*top;
}stack;

  stack* Create(stack *s){
    //创造一个栈
    s=(stack*)malloc(sizeof(stack));
    s->top=s->bottom = (node*)malloc(sizeof(node));
     return s;
  }

   void Insert(stack *s,int i){
      //结点入栈
        node *p = (node*)malloc(sizeof(node));
        p->data=i;
        s->bottom->next=p;
        p->pro=s->bottom;
        s->bottom=s->bottom->next;
   }
   //节点出栈
    void OutStack(stack *s){
       printf("%d",s->bottom->data);
        s->bottom=s->bottom->pro;
    }
  int main()
 {
     stack *s=NULL;
     s=Create(s);
    //节点入栈
     int n;
     scanf("%d",&n);
     int i=0;
     for(;i<n;i++){
            int num;
            scanf("%d",&num);
           Insert(s,num);
     }

    //节点出栈
    while(s->top!=s->bottom){
            OutStack(s);
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值