栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

第三章算法设计题8

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

第三章算法设计题8

第三章算法设计题8 题目描述

我的思路

代码实现
#pragma once
#include 
using namespace std;

#define MAXSIZE 10

//顺序队类型定义
typedef struct
{
	int *base;
	int front;// 队首指针
	int rear;// 队尾指针
} SqQueue;

//初始化队列
void initQueue(SqQueue& Q)
{
	Q.base = new int[MAXSIZE];
	// 队首和队尾指针重合并指向0
	Q.front = Q.rear = 0;
}

//入队(从队头插入
void enQueue(SqQueue& Q, int e)
{
	// 队满
	if (Q.front == (Q.rear + 1 + MAXSIZE) % MAXSIZE) 
	{ 
		cout << "队满!" << endl;
		exit(0);
	}
	else
	{
		 //注意:这里是先入队,再修改指针 
		Q.base[Q.front] = e;
		Q.front = (Q.front - 1 + MAXSIZE) % MAXSIZE;
	}
}

//出队(从队尾出队)
int deQueue(SqQueue& Q, int& e) 
{
	// 队空
	if (Q.rear == Q.front) 
	{ 
		cout << "队空!" << endl;
		exit(0);
	}
	else 
	{
		//先入队,再修改指针
		e = Q.base[Q.rear];
		Q.rear = (Q.rear - 1 + MAXSIZE) % MAXSIZE;
		return e;
	}
}

 //打印队列
void printQueue(SqQueue Q) 
{
	//不为空
	while (Q.rear != Q.front) 
	{	
		Q.front = (Q.front + 1) % MAXSIZE;
		cout << Q.base[Q.front] << " ";
	}
	cout << endl;
}

int main() 
{
	SqQueue Q;
	initQueue(Q);
	int nums[] = { 1,2,3,4,5,6 };
	int len = sizeof(nums) / sizeof(int);
	
	// 将数组中的元素入队
	for (int i = 0; i < len; i++) 
	{
		enQueue(Q, nums[i]);
	}
	// 打印队列
	printQueue(Q);

	// 将元素1出队
	int e;
	deQueue(Q, e);
	// 打印队列
	printQueue(Q);

	system("pause");
	return 0;
}
运行结果

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/513143.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号