博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据结构和算法系列4 队列
阅读量:6541 次
发布时间:2019-06-24

本文共 6763 字,大约阅读时间需要 22 分钟。

上一篇讲了栈,这一篇要总结的是我们常用的队列,我想从以下几个方面进行总结。

1,什么是队列?

2,队列的存储结构?
3,队列的常用操作及实现代码?

1,什么是队列

1,首先,队列也是一种特殊的线性表,它是一种操作受限的线性表。它只允许在表的一端进行元素插入,而在另一端进行元素删除。允许插入的一端称为队尾(rear),允许删除的一端称为队头(font)。

2,对于队列,与现实生活中的排队类似,新加入的成员总是在队尾,而排在队列最前面的总是最先离开队列,即先进先出,因此队列也称为先进先出表(FIFO)。

2,队列的存储结构

实现代码:

///     /// 封装顺序队列    ///     /// 
public class SeqQueue
{ private const int _maxSize = 100; public int MaxSize { get { return _maxSize; } } //保存数据 public T[] data=new T[_maxSize]; //头指针 public int head; //尾指针 public int rear; }

3,队列的常见操作及实现代码

1,初始化队列

思路:构造一个空队列,即将头指针head和尾指针rear都设置为0。

2,入队

思路:若队列不满,则将数据x插入到尾指针rear指向的位置,然后再将rear加1。

3,出队

思路:若队列不空,则将头指针head加1,并返回被删除的元素。

4,取队头

思路:若队列不空,则返回队头元素。

5,取队长

思路:即尾指针rear-头指针head。

6,判队空

思路:只需要判断头指针head与尾指针是否相等即可

7,判队满

思路:只需判断尾指针与MaxSize是否相等即可

注:在一个非空队列中,头指针始终指向队头元素,而尾指针始终指向队尾元素的下一个位置

C#版:

namespace DS.Model{    ///     /// 学生实体    ///     public class Student    {        public int ID { get; set; }        public string Name { get; set; }        public int Age { get; set; }    }}namespace DS.BLL{    ///     /// 队列常见操作逻辑类    ///     public class SeqQueueBLL    {        ///         /// 初始化        ///         /// 
/// ///
public static SeqQueue
Init
(SeqQueue
seqQueue) { seqQueue.head = 0; seqQueue.rear = 0; return seqQueue; } ///
/// 入队 /// ///
///
///
public static SeqQueue
Enter
(SeqQueue
seqQueue,T data) { //是否队满 if (IsFull(seqQueue)) return null; seqQueue.data[seqQueue.rear++] = data; //等价于seqQueue.data[seqQueue.rear] = data; seqQueue.rear++; return seqQueue; } ///
/// 出队 /// ///
///
///
public static T Dequeue
(SeqQueue
seqQueue) { //是否队空 if (IsEmpty(seqQueue)) return default(T); var data = seqQueue.data[seqQueue.head]; seqQueue.head++; return data; } ///
/// 取队头 /// ///
///
///
public static T GetHead
(SeqQueue
seqQueue) { //是否队空 if(IsEmpty(seqQueue)) return default(T); return seqQueue.data[seqQueue.head]; } ///
/// 取队长 /// ///
///
///
public static int GetLength
(SeqQueue
seqQueue) { return seqQueue.rear - seqQueue.head; } ///
/// 判断是否队满 /// ///
///
///
public static bool IsFull
(SeqQueue
seqQueue) { if (seqQueue.rear >= seqQueue.MaxSize) return true; return false; } ///
/// 判断是否队空 /// ///
///
///
public static bool IsEmpty
(SeqQueue
seqQueue) { if (seqQueue.head == seqQueue.rear) return true; return false; } } ///
/// 封装顺序队列 /// ///
public class SeqQueue
{ private const int _maxSize = 100; public int MaxSize { get { return _maxSize; } } //保存数据 public T[] data=new T[_maxSize]; //头指针 public int head; //尾指针 public int rear; }}namespace SeqQueue.CSharp{ class Program { static void Main(string[] args) { SeqQueue
seqQueue = new SeqQueue
(); Console.WriteLine("********************初始化*******************\n"); SeqQueueBLL.Init(seqQueue); Console.WriteLine("当前队列的长度是:{0}", SeqQueueBLL.GetLength(seqQueue)); Console.WriteLine("\n********************入队*******************\n"); Console.WriteLine("插入五条数据到队列\n"); SeqQueueBLL.Enter(seqQueue, new Student { ID = 1, Name = "a", Age = 1 }); SeqQueueBLL.Enter(seqQueue, new Student { ID = 2, Name = "b", Age = 2 }); SeqQueueBLL.Enter(seqQueue, new Student { ID = 3, Name = "c", Age = 3 }); SeqQueueBLL.Enter(seqQueue, new Student { ID = 4, Name = "d", Age = 4 }); SeqQueueBLL.Enter(seqQueue, new Student { ID = 5, Name = "e", Age = 5 }); Display(seqQueue); Console.WriteLine("\n********************出队*******************\n"); Console.WriteLine("将队头出队\n"); Student student= SeqQueueBLL.Dequeue(seqQueue); Display(seqQueue); Console.WriteLine("\n********************取队头*******************\n"); Student result= SeqQueueBLL.GetHead(seqQueue); Console.WriteLine("ID={0},Name={1},Age={2}\n", result.ID, result.Name, result.Age); Console.WriteLine("\n********************取队长*******************\n"); Console.WriteLine("当前队列中有{0}个元素\n",SeqQueueBLL.GetLength(seqQueue)); Console.ReadKey(); } ///
/// 展示数据 /// ///
private static void Display(SeqQueue
seqQueue) { Console.WriteLine("\n*****展示数据*****\n"); for (int i = seqQueue.head; i < seqQueue.rear; i++) { Console.WriteLine("ID={0},Name={1},Age={2}\n", seqQueue.data[i].ID, seqQueue.data[i].Name, seqQueue.data[i].Age); } Console.WriteLine("*****展示完毕*****\n"); } }}

程序运行结果:

 

C语言版:

#include "stdio.h"    #include "stdlib.h"   #include "io.h"  #include "math.h"  #include "time.h"#define OK 1#define ERROR 0#define TRUE 1#define FALSE 0#define MAXSIZE 20typedef int Status; typedef int ElemType;/* 队列的顺序存储结构 */typedef struct{    ElemType data[MAXSIZE];    int head;        /* 头指针 */    int rear;        /* 尾指针,若队列不空,指向队列尾元素的下一个位置 */}SeqQueue;/*初始化*/Status Init(SeqQueue *seqQueue){    seqQueue->head=0;    seqQueue->rear=0;    return OK;}/*入队*/Status Enter(SeqQueue *seqQueue,ElemType e){    //是否队满    if (IsFull(seqQueue)) return ERROR;    seqQueue->data[seqQueue->rear]=e;    seqQueue->rear++;    return OK;    }/*出队*/Status Dequeue(SeqQueue *seqQueue,ElemType *e){    //是否队空    if (IsEmpty(seqQueue)) return ERROR;        *e=seqQueue->data[seqQueue->head]; //为什么不能用e=seqQueue->data[seqQueue->head]    seqQueue->head++;    return OK;}/*取队头*/Status GetHead(SeqQueue *seqQueue,ElemType *e){    //是否队空    if (IsEmpty(seqQueue)) return ERROR;        *e=seqQueue->data[seqQueue->head];    return OK;}/*取队长*/int GetLength(SeqQueue *seqQueue){    return seqQueue->rear-seqQueue->head;}/*是否队满*/Status IsFull(SeqQueue *seqQueue){    if (seqQueue->rear>=MAXSIZE) return TRUE;    return FALSE;}/*是否队空*/Status IsEmpty(SeqQueue *seqQueue){    if (seqQueue->rear==seqQueue->head) return TRUE;    return FALSE;}/*展示数据*/void Display(SeqQueue *seqQueue){    int i;    printf("*****展示数据*****\n");    for (i=seqQueue->head;i
rear;i++) { printf("%d ",seqQueue->data[i]); } printf("\n*****展示完毕*****\n");}void main(){ SeqQueue seqQueue; ElemType e; Status i; int j; printf("***************初始化***************\n"); i=Init(&seqQueue); if (i==OK) printf("初始化成功!\n"); else printf("初始化失败!\n"); printf("\n***************入队***************\n"); printf("插入五条数据到队列\n"); for (j=1;j<6;j++) { i=Enter(&seqQueue,j); } Display(&seqQueue); printf("\n***************出队***************\n"); printf("将队头出队\n"); Dequeue(&seqQueue,&e); Display(&seqQueue); printf("\n***************取队头***************\n"); GetHead(&seqQueue,&e); printf("当前队头元素是:%d\n",e); printf("\n***************取队长***************\n"); printf("当前队列中有%d个元素\n",GetLength(&seqQueue)); getchar();}

程序运行结果:

转载地址:http://rfsdo.baihongyu.com/

你可能感兴趣的文章
Java反射机制详解(3) -java的反射和代理实现IOC模式 模拟spring
查看>>
NIO框架入门(四):Android与MINA2、Netty4的跨平台UDP双向通信实战
查看>>
架构师速成-架构目标之伸缩性\安全性
查看>>
linux中iptables设置自建dns服务器的端口
查看>>
有向图的拓扑排序算法JAVA实现
查看>>
am335x 电容屏驱动添加。
查看>>
Nginx配置中的log_format用法梳理(设置详细的日志格式)
查看>>
从 JavaScript 到 TypeScript
查看>>
Linux常用的服务器构建
查看>>
深入了解 Weex
查看>>
Zeppelin Prefix not found.
查看>>
linux 的网络设置
查看>>
首届“欧亚杯”象翻棋全国团体邀请赛圆满收评!
查看>>
编译tomcat
查看>>
oracle-xe手工创建数据库
查看>>
我的友情链接
查看>>
UG中卸载被占用的DLL
查看>>
eclipse 设置注释模板详解,与导入模板方法介绍总结
查看>>
Cocos2d-x3.2 文字显示
查看>>
mongodb group
查看>>