C#编程(五十)----------栈

栈与队列是一个非常类似的容器,他们的区别在于队列是先进先出,而栈是后进先出.

Stack与Stack<T>,像队列一样,栈也提供了泛型与非泛型版本.

Stack的方法:


方法


说明


Pop()


从栈顶读栈并删除元素


Push()


存放数据,存在栈顶


Peek()


从栈顶读,但不删除

案例:

using System;

using System.Collections;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

namespace 栈

{

class Program

{

static void Main(string[] args)

{

Stack<string> stack = new Stack<string>();

stack.Push("A");

stack.Push("B");

stack.Push("C");

foreach (var item in stack)

{

Console.WriteLine(item);

}

//因为栈是后进先出的,所以结果是CBA

//以上我们使用枚举器,是不会改变元素的,不可以删除

//现在我们用Pop来读取输出

Console.WriteLine("使用Pop方法读取元素");

while (stack.Count!=0)

{

Console.WriteLine(stack.Pop());

}

Console.WriteLine("Pop之后的栈大小: {0}", stack.Count);

Console.ReadKey();

}

}

}

一.创建栈

Stack类的构造函数提供了三种重载形式:


构造函数


说明


public Stack()


使用默认的初始哈容器创建Stack的新实例


public Stack(ICollection col)


使用ICollection集合复制的元素来创建Stack的实例,并具有与集合元素数目相同的初始容量


public Stack(int initialCapacity)


通过自定初始容量来创建Stack类的实例

案例:

Stack sack = new Stack();//使用默认容量

Stack sack1 = new Stack(new string[5] { "堆栈元素一", "堆栈元素二", "堆栈元素三", "堆栈元素四", "堆栈元素五" });//使用由string数组中的几何元素初始化栈对象

Stack sack2 = new Stack(20);//创建栈对象并指定20个元素

二.元素入栈

为了将元素压入栈中,可以调用Stack类的Push方法.这个方法的声明如下:

public virtual void Push(object obj)

这个方法需要一个object类型的参数obj,表示要被压入到栈中的对象.案例:

Stack sk = new Stack();

sk.Push("1");

sk.Push("2");

sk.Push("3");

sk.Push("4");

sk.Push("5");

//显示栈中内容

foreach (var item in sk)

{

Console.WriteLine(item);

}

//可以看到元素额排列顺序是后入栈的排列在最前面,符合后进先出的规范

Console.ReadKey();

三.元素出栈

元素出栈是指:移除Stack顶部的元素,并返回这个元素的引用.可以通过调用Pop方法实现元素出栈.另外Stack还提供了Peek方法,用于获取顶部元素对象,这个方法并不移除顶部元素.这两个方法的声明如下:

public virtual object Peek();

public virtual object Pop();

案例:

Stack sk = new Stack();

sk.Push("1");

sk.Push("2");

sk.Push("3");

sk.Push("4");

sk.Push("5");

//显示栈中内容

foreach (var item in sk)

{

Console.WriteLine(item);

}

//可以看到元素额排列顺序是后入栈的排列在最前面,符合后进先出的规范

Console.WriteLine("栈顶元素是: {0}", sk.Peek()); ;

Console.WriteLine("移除顶部的元素: {0}",sk.Pop());

//显示栈中内容

foreach (var item in sk)

{

Console.WriteLine(item);

}

Console.ReadKey();

时间: 2024-10-29 04:51:36

C#编程(五十)----------栈的相关文章

C#高级编程五十四天----Lookup类和有序字典

Lookup类 Dictionary<Tkey,TValue>只为每个键支持一个值.新类Lookup<Tkey,TValue>是.NET3.5中新增的,它类似与Dictionary<Tkey,TElement>,但把键映射带一个值集上.这个类在程序及System.Core中实现,用System,Linq命名空间定义. Lookup<Tkey,TElement>的方法和属性如下表: 属性名或者方法名 说明 Count 属性Count返回集合中的元素个数 Ite

C#高级编程五十九天----集合的性能

各种集合的性能 许多集合类提供了相同的功能,例如,SortedList类与SortedDictionary类的功能几乎完全相同.但是,其性能常常有很大的区别.SortedList集合使用的内存少,SortedDictionary集合的元素检索速度快. 在MSDN文档中,集合的方法常常有性能提示,给出了以大O(字母)表示的操作时间: O(1) O(log n) O(n) O(1)表示无论集合中有多少数据项,这个操作需要的时间都不变.例如ArrayList类的Add()方法就具有O(1)行为.无论列

C#高级编程五十五天----HashSet和SortedSet

集 饱含不重复元素的集合称为"集(set)". .NET4包含两个集(HashSet<T>和SortedSet<T>),他们都实现ISet<T>接口.HashSet<T>即包含不重复元素的无序列表,SortedSet<T>集包含不重复元素的有序列表. ISet<T>接口提供的方法可以创建合集,交集,或者给出一个集合时另一个集的超集或子集的信息. 案例: //使用HashSet:重复的元素自动被移除,但是不排序 va

C#高级编程五十六天----可观察的集合ObservableCollection

可观察的集合 如果需要集合中的元素核实删除或添加的信息,就可以使用ObservableCollection<T>类. ObservableCollection<T>类表示一个动态数据集合,在添加项,移除项或刷新整个列表时,刺激和将提供通知. 命名空间:System.Collections.ObjectModle 语法:public class ObservableCollection<T>:Collection<T>,INotifyCollectionCha

QT开发(五十)——QT串口编程基础

QT开发(五十)--QT串口编程基础 一.QtSerialPort简介 1.串口通信基础 目前使用最广泛的串口为DB9接口,适用于较近距离的通信.一般小于10米.DB9接口有9个针脚. 串口通信的主要参数如下: A.波特率:衡量通信速度的参数,表示每秒钟传送的bit的个数.例如9600波特表示每秒钟发送9600个bit. B.数据位:衡量通信中实际数据位的参数,当计算机发送一个信息包,实际包含的有效数据位个数. C.停止位:用于表示单个包的最后一位.典型的值为1和2位. D.奇偶校验位:串口通信

shell编程(十五)--- while特殊用法和函数

break:退出循环体 continue:结束本次循环,进入下一次循环. while特殊用法1: while : do done 上述为while的死循环. while特殊用法2: while read LINE do done < /path/to/FILE 作用:通过while读取FILE文件中的每一行,并将其保存在变量LINE中. 函数:function 语法格式: 方法1: function FUNCTIONNAME {     COMMAND } 方法2: FUNCTIONNAME()

“全栈2019”Java第五十四章:多态详解

难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第五十四章:多态详解 下一章 "全栈2019"Java第五十五章:方法的静态绑定与动态绑定 学习小组 加入同步学习小组,共同交流与进步. 方式一:关注头条号Gorhaf,私信"Java学习小组". 方式二:关注公众号Gorhaf,回复"Java学习小组"

“全栈2019”Java第五十五章:方法的静态绑定与动态绑定

难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第五十五章:方法的静态绑定与动态绑定 下一章 "全栈2019"Java第五十六章:多态与字段详解 学习小组 加入同步学习小组,共同交流与进步. 方式一:关注头条号Gorhaf,私信"Java学习小组". 方式二:关注公众号Gorhaf,回复"Java学习小组&q

对于未来编程的十二种预测

凝视水晶球,我们试图寻找未来五年中关于编程会发生什么,哪些会激动人心. 技术领域快速变革着,而用于构建这些技术的工具也随之不断发展.如果你不能超越当前的项目,那你就只能在兔子洞里越陷越深了. 为了帮助您呈现一个精彩的未来,我们预测了未来五年内编程领域将进行的颠覆性变革.由于我们的水晶球的主观色彩很浓,以下这些猜想也许并不是普遍适用的,还有一些或许在五年内不能完全实现.有些虽然已成为了现实,但真理的确立不是一蹴而就的. 亲爱的读者,请你快速阅读吧,因为未来将以超越我们认知的速度发展着. 1. GP

QT开发(五十五)———Qt Quick Controls

QT开发(五十五)---Qt Quick Controls 一.Qt Quick Controls基础 QT5.1发布了Qt Quick的一个全新模块:Qt Quick Controls.Qt Quick Controls模块提供了大量类似Qt Widgets模块的可重用组件. 为了开发基于Qt Quick Controls的程序,需要创建一个Qt Quick Application类型的应用程序,选择组件集的时候注意选择Qt Quick Controls. 二.Qt Quick Control