33-链式栈的有关函数

知识点:

链式栈,用带头结点的单链表实现
栈顶:入栈和出栈,栈顶在表头(入栈和出栈的时间复杂度都是O(1))
链式栈的栈顶在头指针,顺序栈的栈顶在最后面(尾部)

1.结构体

typedef struct LSNode
{
	int data;
	struct LSNode *next;
}LSNode,*PLStack;//PLStack自带*  所以PLStack ps  等同于  PLStack *ps;

2.初始化

void InitStack(PLStack ps)
{
	assert(ps != NULL);
	if(ps == NULL)
		return ;

	ps->next = NULL;
}

初始化测试:

	LSNode s;
	InitStack(&s);

3.入栈 往栈中输入数据(只能在栈顶操作)

bool Push(PLStack ps,int val)
{
	assert(ps != NULL);
	if(ps == NULL)
		return false;

	//创建
	LSNode *p = (LSNode *)malloc(sizeof(LSNode));
	assert(p != NULL);
	//放数据
	p->data = val;
	//链接
	p->next = ps->next;
	ps->next = p;

	return true;
}

入栈测试:

	LSNode s;
	InitStack(&s);
	for(int i = 0;i<13;i++)
	{
		Push(&s,i);
	}
	int val;
	GetTop(&s,&val);
	printf("%d\n",val);

4.获取栈顶元素的值(不删除栈顶元素) 输出参数

bool GetTop(PLStack ps,int *rtval)
{
	assert(ps != NULL);
	if(ps == NULL)
		return false;

	if(IsEmpty(ps))//如果为空表,是可以的,所以不能加到断言里面而省略IsEmpty
	{
		return false;
	}

	*rtval = ps->next->data;

	return true;
}

获取栈顶元素的值(不删除栈顶元素) 测试

	LSNode s;
	InitStack(&s);
	for(int i = 0;i<13;i++)
	{
		Push(&s,i);
	}
	for(int i = 0;i<13;i++)
	{
		int val;
		GetTop(&s,&val);
		printf("%d ",val);
		Pop(&s,&val);
	}

5.获取栈顶元素的值并且删除栈顶元素

bool Pop(PLStack ps,int *rtval)
{
	assert(ps != NULL);
	if(ps == NULL)
		return false;

	if(IsEmpty(ps))
	{
		return false;
	}

	LSNode *p = ps->next;
	*rtval = p->data;
	ps->next = p->next;

	return true;
}

获取栈顶元素的值并且删除栈顶元素 测试

	LSNode s;
	InitStack(&s);
	for(int i = 0;i<13;i++)
	{
		Push(&s,i);
	}
	for(int i = 0;i<20;i++)
	{
		int val;
		if(Pop(&s,&val))
		{
			printf("%d ",val);
		}
		else
			break;
	}

6.判空

bool IsEmpty(PLStack ps)
{
	assert(ps != NULL);
	if(ps == NULL)
		return ;

	return ps->next == NULL;
}

判空测试

LSNode s;
	InitStack(&s);
	//for(int i = 0;i<13;i++)
	//{
	//	Push(&s,i);
	//}
	if(IsEmpty(&s))
		printf("是空链\n");
	else
		printf("不是空链\n");

7.获取栈中有效元素的个数

int GetLength(PLStack ps)
{
	assert(ps != NULL);
	if(ps == NULL)
		return -1;

	int count = 0;
	for(LSNode *p = ps->next;p != NULL;p = p->next)
	{
		count++;
	}

	return count;
}

获取栈中有效元素的个数 测试

LSNode s;
	InitStack(&s);
	for(int i = 0;i<10;i++)
	{
		Push(&s,i);
	}
	int len = GetLength(&s);
	printf("%d\n",len);

8.清空所有数据

void Clear(PLStack ps)
{
	assert(ps != NULL);
	if(ps == NULL)
		return ;

	Destroy(ps);
}

9.销毁数据

void Destroy(PLStack ps)
{
	assert(ps != NULL);
	if(ps == NULL)
		return ;

	//总是删除第一个点
	LSNode *p;
	while(ps->next != NULL)
	{
		p = ps->next;
		ps->next = p->next;
		free(p);
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值