实现链栈(进栈、出栈、读栈、初始化)

#include <stdio.h>
#include <stdlib.h>
typedef struct node{
    int data;
    struct node *next;
} Node;

typedef struct stack{
    Node* top;
    Node* bottom;
    int count;
} *Stack;

void InitStack(Stack &S){
    S = (Stack)malloc(sizeof(stack));
    S->bottom = NULL; 
    S->top = NULL;
    S->count = 0;
}

void Push(Stack &S,int num){
    Node *stone;
    stone = (Node*)malloc(sizeof(Node));
    stone->data = num;
    stone->next = S->top;
    S->top = stone;
    S->count++;
    if(S->bottom == NULL){
        S->bottom = S->top;
    }    
}

void Dispaly(Stack S){
    printf("遍历栈:\n");
    Node* p = (Node*)malloc(sizeof(Node));
    p = S->top;
    if(S->count==0){
        printf("栈中没有数据\n");
    }
    for(int i = 0;i<S->count;i++){
        printf("%d ",p->data);
        p = p->next;
    }
    printf("\n");
}

int Pop(Stack S){
    int elem;
    Node* p = (Node*)malloc(sizeof(Node));
    p = S->top;
    elem = p->data;
    S->top = p->next;
    S->count--;
    free(p);
    return elem;
}

int getTop(Stack S){
    int elem;
    Node* p = (Node*)malloc(sizeof(Node));
    p = S->top;
    elem = p->data;
    return elem;
} 
main(){
    Stack S;
    InitStack(S);
    int num,i,x;
    printf("随机生成10个数并且入栈:\n");
    for(i = 0;i<10;i++){
        num = rand()%100+1;
        printf("%d ",num);
        Push(S,num);
    }
    printf("\n");
    Dispaly(S);    
    num = Pop(S);
    printf("弹出栈顶元素:%d\n",num);
    Dispaly(S);
    num = getTop(S);
    printf("读出栈顶元素:%d\n",num);
    Dispaly(S);
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值