C#中的栈和队列

什么是栈

栈和队列是非常重要的两种数据结构,在软件设计中应用很多。栈和队列也是线性结构,线性表、栈和队列这三种数据结构的数据元素以及数据元素间的逻辑关系完全相同,差别是线性表的操作不受限制,而栈和队列的操作受到眼制。栈的操作只能在表的一端进行,队列的插入操作在表的一端进行而其它操作在表的另一端进行,所以,把栈和队列称为操作受限的线性表。

BCL中的栈

使用原本有的栈

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
​
namespace 栈
{internal class Program{static void Main(string[] args){Stack<char> stack = new Stack<char>();stack.Push('a');stack.Push('b');stack.Push('c');//栈顶数据Console.WriteLine("push a b c之后的数据个数为" + stack.Count);char temp = stack.Pop();//去的栈顶的数据,并把栈顶的数据删除Console.WriteLine("pop 之后的数据是:"+temp);Console.WriteLine("pop 之后栈中数据的个数"+stack.Count);char temp2= stack.Peek();//取出栈顶数据,不删除Console.WriteLine("peek 之后栈中数据的个数" + stack.Count);stack.Clear();Console.WriteLine("clear之后栈中数据的个数" + stack.Count);Console.WriteLine("空栈的时候,去的栈顶的值为"+stack.Peek());//出现异常//空栈的时候不要进行peek和pop操作,否则会出现异常Console.ReadKey();}}
}
​

实现顺序栈

自定义顺序栈
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
​
namespace 栈
{internal interface IStackDS<T>{int Count { get; }//get data numberint Getlenth();bool IsEmpty();void Clear();void Push(T item);T Pop();T Peek();
​}
}
​
​
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
​
namespace 栈
{internal class SeqStack<T> : IStackDS<T>{private T[] data;
​private int top;
​public SeqStack(int size){data = new T[size];top = -1;}public SeqStack():this(10){
​}public int Count{get { return top + 1; }}
​public void Clear(){top = -1;}
​public int Getlenth(){return Count;}
​public bool IsEmpty(){return Count == 0;}
​public T Peek(){return data[top];}
​public T Pop(){T temp = data[top];top--;return temp;}
​public void Push(T item){data[top+1]= item;top++;}}
}
​
​
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
​
namespace 栈
{internal class Program{static void Main(string[] args){SeqStack<char> stack = new SeqStack<char>();stack.Push('a');stack.Push('b');stack.Push('c');//栈顶数据Console.WriteLine("push a b c之后的数据个数为" + stack.Count);char temp = stack.Pop();//去的栈顶的数据,并把栈顶的数据删除Console.WriteLine("pop 之后的数据是:"+temp);Console.WriteLine("pop 之后栈中数据的个数"+stack.Count);char temp2= stack.Peek();//取出栈顶数据,不删除Console.WriteLine("peek 之后栈中数据的个数" + stack.Count);stack.Clear();Console.WriteLine("clear之后栈中数据的个数" + stack.Count);Console.WriteLine("空栈的时候,去的栈顶的值为"+stack.Peek());//出现异常//空栈的时候不要进行peek和pop操作,否则会出现异常Console.ReadKey();}}
}
​

链栈

public class Node<T>
{public T Data { get; set; }public Node<T> Next { get; set; }
​public Node(T data){Data = data;Next = null;}
}
​
public class LinkedStack<T>
{private Node<T> top;
​public LinkedStack(){top = null;}
​// 判断栈是否为空public bool IsEmpty(){return top == null;}
​// 入栈操作public void Push(T data){Node<T> newNode = new Node<T>(data);newNode.Next = top;top = newNode;}
​// 出栈操作public T Pop(){if (IsEmpty()){throw new InvalidOperationException("栈为空,无法执行出栈操作。");}T data = top.Data;top = top.Next;return data;}
​// 查看栈顶元素public T Peek(){if (IsEmpty()){throw new InvalidOperationException("栈为空,无法查看栈顶元素。");}return top.Data;}
​// 清空栈public void Clear(){top = null;}
}
​
// 使用示例
public class Program
{public static void Main(string[] args){LinkedStack<int> stack = new LinkedStack<int>();
​stack.Push(1);stack.Push(2);stack.Push(3);
​Console.WriteLine(stack.Pop());  // 输出 3Console.WriteLine(stack.Peek()); // 输出 2
​stack.Push(4);Console.WriteLine(stack.Pop());  // 输出 4
​while (!stack.IsEmpty()){Console.WriteLine(stack.Pop());}}
}

什么是队列

队列(Queue)是一种遵循先进先出(FIFO,First In First Out)原则的抽象数据类型。在队列中,元素的添加(入队)总是在一端进行,称为队尾(Rear),而元素的移除(出队)总是在另一端进行,称为队首(Front)。

顺序队列

using System;
​
public class SequentialQueue<T>
{private T[] queue;private int head;private int tail;private int count;private int capacity;
​public SequentialQueue(int capacity){this.capacity = capacity;queue = new T[capacity];head = 0;tail = 0;count = 0;}
​// 判断队列是否为空public bool IsEmpty(){return count == 0;}
​// 判断队列是否已满public bool IsFull(){return count == capacity;}
​// 入队操作public void Enqueue(T item){if (IsFull()){throw new InvalidOperationException("队列已满,无法入队。");}queue[tail] = item;tail = (tail + 1) % capacity;count++;}
​// 出队操作public T Dequeue(){if (IsEmpty()){throw new InvalidOperationException("队列为空,无法出队。");}T item = queue[head];queue[head] = default(T); // 清除队首元素head = (head + 1) % capacity;count--;return item;}
​// 查看队首元素public T Peek(){if (IsEmpty()){throw new InvalidOperationException("队列为空,无法查看队首元素。");}return queue[head];}
​// 获取队列的当前元素数量public int Count(){return count;}
}
​
// 使用示例
public class Program
{public static void Main(string[] args){SequentialQueue<int> queue = new SequentialQueue<int>(5);
​queue.Enqueue(1);queue.Enqueue(2);queue.Enqueue(3);
​Console.WriteLine(queue.Dequeue());  // 输出 1Console.WriteLine(queue.Peek());     // 输出 2
​queue.Enqueue(4);queue.Enqueue(5);queue.Enqueue(6);
​while (!queue.IsEmpty()){Console.WriteLine(queue.Dequeue());}}
}

链队列

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/873849.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

安卓篇-unidbg初步测试

前言:目前app的进度是c层的md5魔改 已经做好,又套了一层java层的加密。刚好可以再熟悉一下unidbg 最新版的app ,作为demo测试一下。 分析先看下app 的反编译的结果,很明显,源码很清晰 ,之前的混淆方式一点用没有。 然后跳过去 /* loaded from: classes4.dex */ public c…

FPGA实验5:4位加法计数器

实验目的及要求 掌握时钟信号、进程和BUFFER端口的运用&#xff1b;了解计数器的设计、仿真和硬件测试&#xff0c;进一步熟悉VHDL语句、语法及应用等。 实验原理 运用Quartus II 集成环境下的VHDL文本设计方法设计4位加法计数器&#xff0c;进行波形仿真和分析、引脚分配…

4 Java的基本程序设计结构(基本语法3)- 字符串、面向对象(进阶)

文章目录 前言一、java中的 究竟比较的是什么&#xff1f;二、字符串1 String&#xff08;1&#xff09;String的两种构造方式&#xff08;2&#xff09;字符数组转字符串、字节数组转字符串&#xff08;3&#xff09;字符串的 拼接&#xff08;4&#xff09;字符串的内存结构…

【Android面试八股文】荣耀面试算法题:输入一个N阶方阵(0<N<10),输出此方阵顺时针旋转M(0<=M<=10000)次后的方阵

文章目录 1. 算法题:输入一个N阶方阵(0<N<10),输出此方阵顺时针旋转M(0<=M<=10000)次后的方阵1.1 题目描述1.2 算法实现1.2.1 步骤说明:1.2.2 算法实现1.2.3 代码实现:1.2.4 程序说明:1.2.5 示例详细讲解如何将一个矩阵顺时针旋转90度1. 算法题:输入一个N阶方…

Spring -- 三层架构

T04BF &#x1f44b;专栏: 算法|JAVA|MySQL|C语言 &#x1faf5; 今天你敲代码了吗 应用分层 介绍 在阿里的开发手册里,关于工程结构部分,定义的常见工程的应用分层结构 那么什么是应用分层呢? 应用分层是一种软件开发设计思想,他将应用程序分层N个层次.这N个层次分别负责各…

Oracle小白菜鸟从入门到精通教程

前言 Oracle公司&#xff08;甲骨文&#xff09;是全球最大的信息管理软件及服务供应商&#xff0c;成立于1977年&#xff0c;总部位于美国加州Redwood shore&#xff0c;面向全球开放oracle认证。Oracle开发的关系数据库产品因性能卓越而闻名&#xff0c;Oracle数据库产品为财…

Hi6274 反激式20瓦电源芯片

HI6274为高性能多模式 PWM 反激式20瓦电源芯片。HI6274较少的外围元器件、较低的系统成本可设计出高性能的"无Y"开关电源。HI6274提供了极为全面和性能优异的智能化保护功能&#xff0c;包括逐周期过流保护、过载保护、软启动、芯片过温保护、可编程输出过压保护功能…

【Langchain大语言模型开发教程】记忆

&#x1f517; LangChain for LLM Application Development - DeepLearning.AI 学习目标 1、Langchain的历史记忆 ConversationBufferMemory 2、基于窗口限制的临时记忆 ConversationBufferWindowMemory 3、基于Token数量的临时记忆 ConversationTokenBufferMemory 4、基于历史…

世界启动Ⅷ--AI视频制作-方案与创新

1.文本/图片生成视频顾名思义&#xff0c;就是输入一段文本描述/上传一张图片即可生成对应的视频。我们常见的Runway、Pika、NeverEnds、Pixverse、svd等都属于此类。比如runway的影视风格Pika的动漫风格NeverEnds的人像模特当然还有一些外延应用&#xff0c;例如最近比较火的阿…

《从C/C++到Java入门指南》- 17.命令行参数

命令行参数 一直写代码的童鞋可能留意到了&#xff0c;main函数中会传入一个String args[]的字符串数组。 这个数组由JVM接收用户输入并传给main函数。 import java.util.*; public class Main {public static void main(String[] args) {for (String arg : args) {System.out…

FLINK-运行架构

为什么要学习Flink运行架构&#xff1f; 虽然现在大厂的开发工具都非常高效、只需要进行参数配置、Flink-sql写业务逻辑&#xff0c;但是在资源配置逻辑优化上不可避免需要了解底层的组件配置。面试时可能也会被问到FLINK是如何进行资源分配、作业运行的等。 以下是在学习时记录…

R语言画散点图-饼图-折线图-柱状图-箱线图-直方图-等高线图-曲线图-热力图-雷达图-韦恩图(二D)

R语言画散点图-饼图-折线图-柱状图-箱线图-直方图-等高线图-曲线图-热力图-雷达图-韦恩图&#xff08;二D&#xff09; 散点图示例解析效果 饼图示例解析效果 折线图示例解析效果 柱状图示例解析效果 箱线图示例解析效果 直方图示例解析效果 等高线图使用filled.contour函数示例…

Python学习—open函数,json与pickle知识点,Os模块详解

目录 1. Open函数 2.json与pickle模块 json模块 1. json.dumps() 2. json.dump() 3. json.loads() 4. json.load() pickle 模块 1. pickle.dumps() 2. pickle.dump() 3. pickle.loads() 4. pickle.load() 3.Os模块 1. Open函数 在Python中&#xff0c;open() 函数…

Jenkins+Maven+Gitlab+Tomcat自动化构建打包+部署

目录 环境准备 导入项目包 配置jenkins 构建项目 配置项目上线 修改项目代码测试 环境准备 本实操项目环境基于https://blog.csdn.net/Lzcsfg/article/details/140359830 首先在node01主机中操作&#xff0c;本次操作需要java8的版本&#xff0c;将之前安装的java17卸…

IoTDB 分段查询语句详解:GROUP BY + 时序语义

GROUP BY 查询子句的时序语义展开&#xff0c;IoTDB 支持的分段方式总结&#xff01; 存储的数据通过分析来发挥价值&#xff0c;当一组被存储的数据通过查询得到分析后的结果时&#xff0c;这些数据才真正在数据库中实现了价值闭环。 在关系型数据库中&#xff0c;GROUP BY 子…

陀螺仪LSM6DS3TR-C的简单使用

文章目录 一、前言二、硬件1.引脚说明2.原理图 三、软件1.IIC读写函数1.1 读函数1.2 写函数 2.初始化2.1 检测设备是否存在2.2 读取LSM6DS3TRC器件ID2.3 LSM6DS3TRC重启&#xff0c;重置寄存器2.5 LSM6DS3TRC设置块数据更新2.6 LSM6DS3TRC设置加速度计的数据采样率2.7 LSM6DS3T…

剪画小程序:刷到好听的音频怎么将音频保存到手机里

在这个短视频盛行的时代&#xff0c;相信很多朋友都和我一样&#xff0c;常常会被那些精彩视频中的背景音乐深深吸引。 比如我&#xff0c;特别喜欢听歌&#xff0c;这段时间在短视频平台上刷到了好多好看的视频&#xff0c;里面的背景音乐简直绝绝子&#xff01; 那么&#x…

【数据分享】2013-2022年我国省市县三级的逐年SO2数据(excel\shp格式\免费获取)

空气质量数据是在我们日常研究中经常使用的数据&#xff01;之前我们给大家分享了2000——2022年的省市县三级的逐年PM2.5数据和2013-2022年的省市县三级的逐年CO数据&#xff08;均可查看之前的文章获悉详情&#xff09;&#xff01; 本次我们分享的是我国2013——2022年的省…

《样式设计011:模组-瓷片区》

描述&#xff1a;在开发小程序过程中&#xff0c;发现一些不错的案例&#xff0c;平时使用也比较多&#xff0c;稍微总结了下经验&#xff0c;以下内容可以直接复制使用&#xff0c;希望对大家有所帮助&#xff0c;废话不多说直接上干货&#xff01; 一、小程序&#xff1a;模组…

TeraTerm 使用技巧

参考资料 自分がよく使うTeratermマクロによる自動ログインのやり方をまとめてみたよTera Term マクロでログインを自動化してみたTera Term のススメ 目录 简介一. 常用基础设置1.1 语言变更1.2 log设置 二. 小技巧2.1 指定host别名2.2 新开窗口2.3 设置粘贴多行命令时的行间…