数据结构基础之队列

队列是一种先进先出的线性表,只允许在表的一端进行插入,另一端进行删除元素,允许插入的一端称为队头,front,允许删除的一端称为队尾,rear。

顺序循环队列的基本运算如下:

#define QueueSize 60
typedef struct Squeue
{//定义顺序循环队列,避免"假溢出"
	DataType queue[QueueSize];
	int front,rear;
}SeqQueue;

void InitQueue(SeqQueue *SCQ)
{//初始化
	SCQ->front=SCQ->rear=0;
}

int QueueEmpty(SeqQueue SCQ)
{//判断队列是否为空,为空返回1,否则返回0
	if(SCQ.front==SCQ.rear)
	return 1;
    else
		return 0;
}

int EnQueue(SeqQueue *SCQ,DataType e)
{//将e插入到顺序循环队列SQ中,成功返回1,否则为0
	if(SCQ->front==(SCQ->rear+1)%QueueSize)
		return 0;
	SCQ->queue[SCQ->rear]=e;
	SCQ->rear=(SCQ->rear+1)%QueueSize;
	return 1;
}

int DeQueue(Squeue *SCQ,DataType *e)
{//将对头元素出对,并赋给e,成功返回1,否则为0,指针回送
		if(SCQ->front==SCQ->rear)
			return 0;
		else
		{
			*e=SCQ->queue[SCQ->front];
			SCQ->front=(SCQ->front+1)%QueueSize;   //这个表达方式循环特有,相当于是front=front+1,指针后移
			return 1;                                                
		}
}

int GetHead(Squeue SCQ,DataType *e)
{//取对头元素,并将元素赋给e,成功返回1,否则为0
	if(SCQ.front==SCQ.rear)
		return 0;
	else
	{
		*e=SCQ.queue[SCQ.front];
		return 1;
	}
}

void ClearQueue(SeqQueue *SCQ)
{//清空队列
	SCQ->front=SCQ->rear=0;
}
舞会上,男生和女生各排成一队,跳舞开始男生和女生的队头各出一人配成舞伴。如果初始人数不相同,较长那一队中
为配对的等待下一轮,算法如下:

#include"stdio.h"
typedef struct
{
	char name[20];
	char sex;// 'F'女,‘M’男
}Person;
typedef Person DataType;
#include"SeqQueue.h"
int DancerCount(SeqQueue Q);
void DancePartner(DataType dancer[],int num)
{
	int i;
	DataType p;
	SeqQueue Mdancers,Fdancers;
	InitQueue(&Mdancers);
	InitQueue(&Fdancers);
	for(i=0;i<num;i++)  //入队
	{
		p=dancer[i];
		if(p.sex=='F')
			EnQueue(&Fdancers,p);
		else
			EnQueue(&Mdancers,p);
	}
	printf("配对成功的舞伴是:\n");
	while(!QueueEmpty(Fdancers)&&!QueueEmpty(Mdancers))
	{
		DeQueue(&Fdancers,&p);//女士出队
		printf("%s    ",p.name);
		DeQueue(&Mdancers,&p);//男士出队
		printf("%s\n   ",p.name);
	}
	if(!QueueEmpty(Fdancers))
	{
		printf("还有%d个女生剩下\n",DancerCount(Fdancers));
		GetHead(Fdancers,&p);
		printf("%s将在下一轮中先得到舞伴",p.name);
	}
	else if(!QueueEmpty(Mdancers))
	{
		printf("还有%d个男生剩下\n",DancerCount(Mdancers));
		GetHead(Mdancers,&p);
		printf("%s将在下一轮中先得到舞伴",p.name);
	}
}

int DancerCount(SeqQueue Q)
{
	return (Q.rear-Q.front+QueueSize)%QueueSize;
}

void main()
{
	int i,n;
	DataType dancer[30];
	printf("舞池中排队人数:");
	scanf("%d",&n);
	for(i=0;i<n;i++)
	{
		printf("姓名:");
		scanf("%s",&dancer[i].name);
		getchar();
		printf("性别:");
		scanf("%c",&dancer[i].sex);
	}
	DancePartner(dancer,n);
}
执行结果如下:

参考:《数据结构》——陈锐



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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值