基础数据结构——链式栈

// 链式栈的实现
#include<iostream>
#include<stdlib.h>
using namespace std;
typedef int type;
typedef struct LinkNode{
	type data;
	struct LinkNode *next;
}Node ,*Stack;
//初始化栈 
void init(Stack &stack){
	stack=(Stack)malloc(sizeof(Node));
	stack->next=NULL; 
} 
//判栈空 
bool isEmpty(Stack &stack){
	 return stack->next==NULL;
}
//返回栈的大小
int size(Stack stack){
	int len=0;
	Stack s=stack->next;
	while(s){
		len++;
		s=s->next;
	}
	return len;
} 
/**
	进栈操作  因为栈只维护栈顶的元素  
	所以采用一个带头节点的链表比较容易实现算法 
**/ 
void push(Stack &stack,type x){
	 Node *s=(Stack)malloc(sizeof(Node));
	 s->data=x;
	 s->next=stack->next;
	 stack->next=s; 
} 
//出栈操作
type pop(Stack &stack){
	if(isEmpty(stack)) return -1;
	Node *s=(Stack)malloc(sizeof(Node));
	s=stack->next;
	stack->next=s->next;
	int x=s->data;
	free(s);
	return x; 
} 
// 返回栈顶元素值
type top(Stack &stack){
	if(isEmpty(stack)) return -1;
	return stack->next->data;
} 
//销毁栈 
void destroy(Stack &stack){
	Stack p;
	
	while(stack){
		p=stack->next;
		free(stack);
		stack=p;
	}
} 

int main(){
	Stack stack;
	init(stack);
	type x;
	cin>>x;
	while(x!=-999){
		push(stack,x);
		cin>>x;
	}
	cout<<top(stack)<<endl;
	cout<<size(stack)<<endl;
	while(!isEmpty(stack)){
		cout<<pop(stack)<<" ";
	}
	cout<<endl;
	return 0;
}


有不足之处,欢迎留言指正!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值