#include <stdio.h>
#include <stdlib.h>

//queue  先进先出 FIFO
//Stack	 先进后出 FILO

typedef int Boo;
#define TRUE 1;
#define False 0;

typedef struct Node
{
	int id;
	struct Node *p;
}stack;

void Push(stack **pptop,int id);  //入栈
Boo kong(stack *pptop);
stack *Pop(stack **pptop);   //出栈
int main()
{
	int i;
	stack *ptop = NULL;
	stack *pmark = NULL;
	Push(&ptop,1);
	Push(&ptop,2);
	Push(&ptop,3);
	Push(&ptop,4);
	pmark = Pop(&ptop);
	/*while(ptop != NULL)
	{
		printf("%d\n",ptop ->id);
		ptop = ptop ->p;
	}*/
	return 0;

}

void Push(stack **pptop,int id)
{
	stack *ptemp = (stack *)malloc(sizeof(stack));
	ptemp ->id = id;
	ptemp ->p = NULL;
	//判断栈里是否有节点
	//没有
	if(*pptop == NULL)
	{
		//栈顶指针指向新来的节点
		*pptop = ptemp;
	}
	else
	{
		//新来的节点的指针指向栈顶
		ptemp ->p = *pptop;
		//栈顶指针指向新来的节点
		*pptop = ptemp;
	}

}

Boo kong(stack *pptop)
{
	int count = 0;
	while(pptop != NULL)
	{
		count ++;
		pptop = pptop ->p;
	}
	if(count == 0)
		return TRUE;

	return False;
}

stack *Pop(stack **pptop)
{
	stack *pMark =NULL;
	if(!kong(*pptop) )  //kong(*pptop) == 0
	{
		pMark = *pptop;
		*pptop = (*pptop)->p;
		pMark->p = NULL;
	}
	return pMark;

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值