9.栈与队列的简单应用


#include "stdafx.h"
#include<stdlib.h>
#include<Windows.h>

int*p = NULL;
int len = 0;

void print();//遍历
void push(int data);//新增加数据
void pop_Stack();//出栈
void pop_Queue();//出队列
int get_Top();//获取栈顶元素
int get_Queue();//获取队列元素

int main()
{
	printf("original:");
	for (int i = 0; i<9; i++)
	{
		push(i + 1);
	}
	print();//遍历

	printf("Queue:   ");
	while (len)
	{
		Sleep(500);
		printf("%d ", get_Queue());
		pop_Queue();
	}

	printf("\n");
	
	printf("Stack:   ");
	for (int i = 0; i<9; i++)
	{
		push(i + 1);
	}

	while (len)
	{
		Sleep(500);
		printf("%d ", get_Top());
		pop_Stack();
	}
	printf("\n");
	system("pause");
	return 0;
}

![运行结果](https://img-blog.csdnimg.cn/20190309222815847.png)

//入栈  入队
void push(int data)
{
	//1.新开内存
	int* pNew = (int*)malloc((len + 1)*sizeof(int));
	//2.判断原来是否有数据
	if (p)
	{
		//3.如果有数据,则拷贝到新开内存中
		memcpy(pNew, p, sizeof(int)*len);
		//4.释放原有内存
		free(p);
	}
	//5.p指向新开内存
	p = pNew;
	//6.数据放到最后,len加一
	p[len++] = data;
}

//出队
void pop_Queue()
{
	if (p == NULL)
	{
		printf("队列没有了!\n");
		return;
	}

	if (len == 1)
	{
		free(p);
		p = NULL;
		len--;
		return;
	}

	//新开内存
	int* pNew = (int*)malloc(sizeof(int)*(len - 1));

	//拷贝数据到新开内存
	memcpy(pNew, p + 1, sizeof(int)*(len - 1));

	//释放原有内存
	free(p);

	//p指向新内存
	p = pNew;

	//len减一
	len--;
}

//获取队列第一个元素
int get_Queue()
{
	return p[0];
}

//获取栈顶元素
int get_Top()
{
	return p[len - 1];
}

//出栈
void pop_Stack()
{
	//判断能否出栈
	if (p == NULL)//防御性编程
	{
		printf("栈空了!\n");
		return;
	}

	if (len == 1)
	{
		free(p);
		p = NULL;
		len--;
		return;
	}

	//新开内存
	int* pNew = (int*)malloc(sizeof(int)*(len - 1));

	//拷贝数据
	memcpy(pNew, p, sizeof(int)*(len - 1));

	//释放原有数据
	free(p);

	//p指向新开内存
	p = pNew;

	//len-1
	len--;
}

//遍历
void print()
{
	for (int i = 0; i < len; i++)
	{
		printf("%d ", p[i]);
	}
	printf("\n");
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值