C#数据结构-队列
队列作为线性表的另一个数据结构,只允许在表的前端进行删除操作,而在表的后端进行插入操作,和栈一样,队列是一种操作受限制的线性表。
先来看下用法:
Queue queue = new Queue();
queue.Enqueue(1);
queue.Enqueue(2);
queue.Enqueue(3);
queue.Enqueue(4);
foreach (var r in queue)
{
Console.Write($"data:{r} ");
}
Console.WriteLine();
Console.WriteLine($"peek:{queue.Peek()}");
queue.Dequeue();
queue.Enqueue(5);
queue.Enqueue(6);
Console.WriteLine();
打印结果:

public class MyQueue
{
/// <summary>
/// 存储栈结构
/// </summary>
public object[] content { get; set; }
/// <summary>
/// 队列第一个节点
/// </summary>
public int head { get; set; }
/// <summary>
/// 对列最后一个节点
/// </summary>
public int tail { get; set; }
/// <summary>
/// 队列长度
/// </summary>
public int size { get; set; }
/// <summary>
/// 增长因子 100 == 1.0
/// </summary>
public int growFactor { get; set; }
/// <summary>
/// 最小增加量
/// </summary>
private const int minimumGrow = 4;
private const int _ShrinkThreshold = 32;
/// <summary>
/// 初始化
/// </summary>
public MyQueue()
: this(32, (float)2.0)
{
}
/// <summary>
///
/// </summary>
/// <param name="capacity">队列长度</param>
/// <param name="growFactor">增长因子</param>
public MyQueue(int capacity, float _growFactor)
{
if (capacity < 0)
throw new ArgumentOutOfRangeException("参数错误");
if (!(_growFactor >= 1.0 && _growFactor <= 10.0))
throw new ArgumentOutOfRangeException("增长因子不在范围内");
content = new Object[capacity];
head = 0;
tail = 0;
size = 0;
growFactor = (int)(_growFactor * 100);
}
/// <summary>
/// 在队列尾处添加节点
/// </summary>
/// <param name="obj"></param>
public virtual void Enqueue(object obj)
{
if (size == content.Length)
{
//计算扩展后的队列长度
int newCapacity = (int)(content.Length * growFactor / 100);
if (newCapacity < content.Length + newCapacity)
{
newCapacity = content.Length + minimumGrow;
}
SetCapacity(newCapacity);
}
content[tail] = obj;
tail = (tail + 1) % content.Length;
size++;
}
/// <summary>
/// 在队列头部出栈
/// </summary>
/// <returns></returns>
public virtual Object Dequeue()
{
if (size == 0)
throw new IndexOutOfRangeException("空队列");
object rem = content[head];
content[head] = null;
head = (head + 1) % content.Length;
size--;
return rem;
}
public virtual Object Peek()
{
if (size == 0)
throw new IndexOutOfRangeException("空队列");
return content[head];
}
/// <summary>
/// 扩展队列
/// </summary>
/// <param name="capacity"></param>
private void SetCapacity(int capacity)
{
object[] newArray = new object[capacity];
if (size > 0)
{
if (head < tail)
{
Array.Copy(content, head, newArray, 0, size);
}
else
{
Array.Copy(content, head, newArray, 0, content.Length - head);
Array.Copy(content, 0, newArray, content.Length - head, head);
}
}
content = newArray;
head = 0;
tail = (size == capacity) ? 0 : size;
}
public void ShowAll()
{
for (int i = head; i < size; i++)
{
Console.Write($"index:{i},data:{content[i]} ");
}
Console.WriteLine("——————————————————————");
}
}
测试:
MyQueue queue = new MyQueue();
queue.Enqueue(1);
queue.Enqueue(2);
queue.Enqueue(3);
queue.Enqueue(4);
queue.ShowAll();
Console.WriteLine($"peek:{queue.Peek()}");
queue.Dequeue();
queue.Enqueue(5);
queue.Enqueue(6);
queue.ShowAll();
Console.ReadLine();
实现方式:
通过object对象数组,存储队列中的节点数据,另外定义两个指针分别指向队列的头部节点以及尾部节点。
Enqueue入队时,(如果队列长度达到数组最大长度,则通过扩展数组(队列长度 * 增长因子)来增加数组长度)通过在对尾附加节点来实现的。
Dequeue出队时,通过头指针后移实现出队列。
另外未实现地方,为节省内存空间,数组中出队后的空间也要加入到后续入队时用到的闲置位置。
以上方法都是以虚方法的方式实现的,便于后续重写(例如线程安全队列)。
打印结果:


C#数据结构-队列的更多相关文章
- java 数据结构 队列的实现
java 数据结构队列的代码实现,可以简单的进行入队列和出队列的操作 /** * java数据结构之队列的实现 * 2016/4/27 **/ package cn.Link; import java ...
- C++ 泛型 编写的 数据结构 队列
平时编程里经常需要用到数据结构,比如 栈和队列 等, 为了避免每次用到都需要重新编写的麻烦现将 C++ 编写的 数据结构 队列 记录下来,以备后用. 将 数据结构 队列 用头文件的形式写成 ...
- C语言数据结构-队列的实现-初始化、销毁、清空、长度、队列头元素、插入、删除、显示操作
1.数据结构-队列的实现-C语言 //队列的存储结构 #define MAXSIZE 100 typedef struct { int* base; //基地址 int _front; //头指针 i ...
- java数据结构——队列、循环队列(Queue)
每天进步一点点,坚持就是成功. 1.队列 /** * 人无完人,如有bug,还请斧正 * 继续学习Java数据结构————队列(列队) * 队列和栈一样,都是使用数组,但是队列多了一个队头,队头访问数 ...
- [从今天开始修炼数据结构]队列、循环队列、PriorityQueue的原理及实现
[从今天开始修炼数据结构]基本概念 [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList [从今天开始修炼数据结构]栈.斐波那契数列.逆波兰四则运 ...
- (js描述的)数据结构[队列结构,优先级队列](3)
(js描述的)数据结构[队列结构](3) 一.队列结构的特点: 1.基于数组来实现,的一种受限的线性结构. 2.只允许在表头进行删除操作,在表尾进行插入操作. 3.先进先出(FIFO) 二.队列的一些 ...
- 数据结构--队列(Java实现)
数据结构--队列(Java实现) 博客说明 文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢! 简介 队列是一种特殊的线性表,特殊之处在于它只 ...
- 数据结构--队列之C数组实现
队列是一种限定操作的线性表,它只能在表的一段插入,另外一段取出.所以也称为先进先出数据结构(FIFO---First In First Out) C代码如下: #include<stdio.h& ...
- JavaScript数据结构——队列的实现
前面楼主简单介绍了JavaScript数据结构栈的实现,http://www.cnblogs.com/qq503665965/p/6537894.html,本次将介绍队列的实现. 队列是一种特殊的线性 ...
- 用go实现常用算法与数据结构——队列(queue)
queue 简介 队列是一种非常常见的数据结构,日常生活中也能经常看到.一个典型的队列如下图(图片来自 segmentfault): 可以看出队列和我们日常生活中排队是基本一致的.都遵循 FIFO(F ...
随机推荐
- [LeetCode]子串的最大出现次数(字符串)
题目 给你一个字符串 s ,请你返回满足以下条件且出现次数最大的 任意 子串的出现次数: 子串中不同字母的数目必须小于等于 maxLetters . 子串的长度必须大于等于 minSize 且小于等于 ...
- 并发编程中死锁、递归锁、进程/线程池、协程TCP服务器并发等知识点
1.死锁 定义; 类似两个人分别被囚禁在两间房子里,A手上拿着的是B囚禁房间的钥匙,而B拿着A的钥匙,两个人都没法出去,没法给对方开锁,进而造成死锁现象.具体例子代码如下: # -*-coding:u ...
- react项目结合echarts,百度地图实现热力图
一.最近在一个react项目(antd pro)中需要展示一个热力地图.需求是: 1.热力地图可缩放: 2.鼠标点击可以展示该点地理坐标,及热力值. 3.初始化时候自适应展示所有的热力点. 4.展示热 ...
- Infor EAM:注重行业属性,实现对轨道交通线性资产的可视化管理
Infor EAM:注重行业属性,实现对轨道交通线性资产的可视化管理 企业得利,一要开源,二要节流.而企业资产管理的目的,也正是从资产的角度出发,一方面通过相关资源与活动的合理安排提高设备可利用率.增 ...
- bash运行脚本的几种方式
转载自https://www.jianshu.com/p/ba6efda13e23 转载地址:http://www.jquerycn.cn/a_8354 bash shell 脚本执行的方法有多种,本 ...
- java虚拟机小贴士之GC分析
打印日志 通过加入 -XX:+PrintGCDetails 参数则可以打印详细GC信息至控制台.参数-verbose:gc也是可以,但不够详细.通过加入-XX:+PrintGCDateStamps则可 ...
- 关于KeePass实现mstsc远程桌面(rdp协议)的自动登录
本文的Keepass版本:KeePass Password Safe Version 2.45 首先介绍一下Keepass,引用官网的解释如下: KeePass is a free open sour ...
- WAF的那些事
介绍WAF 本节主要介绍WAF (Web Application Firewall, Web应用防火墙)及与其相关的知识,这里利用国际上公认的一种说法: Web应用防火墙是通过执行系列针对HTTP/H ...
- Mac Catalina 下 gdb codesign问题解决
在 macOS 上,无法直接使用 gdb 进行 debug. 这是因为 Darwin 内核在你没有特殊权限的情况下,不允许调试其它进程.调试某个进程,意味着你对这个进程有完全的控制权限,所以为了防止被 ...
- Python练习题 016:猴子吃桃
[Python练习题 016] 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个.第二天早上又将剩下的桃子吃掉一半,又多吃了一个.以后每天早上都吃了前一天剩下的一半零一个.到 ...