栈操作

#include<stdio.h>
#include<stdlib.h>
struct Node{
	int data;
	struct Node *pointer;
};
struct Stack{
	struct Node *top;
	struct Node *bottom;
};
struct Stack *Stack_Construct(void);
char Stack_Push(struct Stack *pstack,int a);
char Stack_Empty(struct Stack stack);
int Stack_Pop(struct Stack *pstack);
int  main()
{
	struct Stack *pstack=Stack_Construct();
	Stack_Push(pstack,2);
	Stack_Push(pstack,4);
	Stack_Push(pstack,6);
	Stack_Push(pstack,7);
	Stack_Push(pstack,3);
	Stack_Push(pstack,1);
	while(Stack_Empty(*pstack)!=1)
		printf("%6d",Stack_Pop(pstack));
	return 1;
}
struct Stack *Stack_Construct(void)
{
	struct Stack *pstack=(struct Stack*)malloc(sizeof(struct Stack));
	struct Node *pNode=(struct Node *)malloc(sizeof(struct Node));
	pstack->top=pNode;
	pstack->bottom=pNode;
	pNode->pointer=NULL;
	return pstack;
}
char Stack_Push(struct Stack *pstack,int a)
{
	struct Node *tempnode;
	struct Node *pNode=(struct Node*)malloc(sizeof(struct Node));
	tempnode=pstack->top;
	pstack->top=pNode;
	pNode->data=a;
	pNode->pointer=tempnode;
}
char Stack_Empty(struct Stack stack)
{
	if(stack.top==stack.bottom)
		return 1;
		else return 0;
}
int Stack_Pop(struct Stack *pstack)
{
	struct Node *tempnode;
	int temp;
	if(Stack_Empty(*pstack)==1){
		printf("Sorry,but the stack is empty");
		return -1;
	}
	tempnode=pstack->top;
	pstack->top=tempnode->pointer;
	temp=tempnode->data;
	free(tempnode);
	return temp;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值