C#棧和隊(duì)列的簡介,算法與應(yīng)用簡單實(shí)例
堆棧(Stack)
代表了一個后進(jìn)先出的對象集合。當(dāng)您需要對各項(xiàng)進(jìn)行后進(jìn)先出的訪問時,則使用堆棧。當(dāng)您在列表中添加一項(xiàng),稱為推入元素,當(dāng)您從列表中移除一項(xiàng)時,稱為彈出元素。
常用方法:
1 public virtual void Clear();
從 Stack 中移除所有的元素。
2 public virtual bool Contains( object obj );
判斷某個元素是否在 Stack 中。
3 public virtual object Peek();
返回在 Stack 的頂部的對象,但不移除它。
4 public virtual object Pop();
移除并返回在 Stack 的頂部的對象。
5 public virtual void Push( object obj );
向 Stack 的頂部添加一個對象。
6 public virtual object[] ToArray();
復(fù)制 Stack 到一個新的數(shù)組中。
========================================================
隊(duì)列(Queue)
代表了一個先進(jìn)先出的對象集合。當(dāng)您需要對各項(xiàng)進(jìn)行先進(jìn)先出的訪問時,則使用隊(duì)列。當(dāng)您在列表中添加一項(xiàng),稱為入隊(duì),當(dāng)您從列表中移除一項(xiàng)時,稱為出隊(duì)。
常用方法:
1 public virtual void Clear();
從 Queue 中移除所有的元素。
2 public virtual bool Contains( object obj );
判斷某個元素是否在 Queue 中。
3 public virtual object Dequeue();
移除并返回在 Queue 的開頭的對象。
4 public virtual void Enqueue( object obj );
向 Queue 的末尾添加一個對象。
5 public virtual object[] ToArray();
復(fù)制 Queue 到一個新的數(shù)組中。
6 public virtual void TrimToSize();
設(shè)置容量為 Queue 中元素的實(shí)際個數(shù)。
=========================================================
簡單實(shí)例:
編程判斷一個字符串是否是回文?;匚氖侵敢粋€字符序列以中間字符為基準(zhǔn)兩邊字符完全相同,如字符序列“ACBDEDBCA”是回文。
算法思想:
判斷一個字符序列是否是回文,就是把第一個字符與最后一個字符相比較,第二個字符與倒數(shù)第二個字符比較,依次類推,第 i 個字符與第 n-i個字符比較。如果每次比較都相等,則為回文,如果某次比較不相等,就不是回文。因此,可以把字符序列分別入隊(duì)列和棧,然后逐個出隊(duì)列和出棧并比較出隊(duì)列的字符和出棧的字符是否相等,若全部相等則該字符序列就是回文,否則就不是回文。
using System;
using System.Collections.Generic;
namespace 棧和隊(duì)列舉例
{
class Program
{
static void Main(string[] args)
{
string str = Console.ReadLine();
Stack<char> stack = new Stack<char>();
Queue<char> queue = new Queue<char>();
for (int i = 0; i < str.Length; i++)
{
stack.Push(str[i]);
queue.Enqueue(str[i]);
}
bool isHui = true;
while(stack.Count > 0)
{
if(stack.Pop() != queue.Dequeue())
{
isHui = false;
break;
}
}
Console.WriteLine("是否回文字符串:" + isHui);
Console.ReadKey();
}
}
}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
- C#實(shí)現(xiàn)斐波那契數(shù)列的幾種方法整理
- c#基礎(chǔ)系列之ref和out的深入理解
- c#基礎(chǔ)系列之System.String的深入理解
- c#基礎(chǔ)系列之值類型和引用類型的深入理解
- C#類繼承中構(gòu)造函數(shù)的執(zhí)行序列示例詳解
- C#溫故而知新系列教程之閉包
- C#環(huán)形隊(duì)列的實(shí)現(xiàn)方法詳解
- C#環(huán)形緩沖區(qū)(隊(duì)列)完全實(shí)現(xiàn)
- C#數(shù)據(jù)結(jié)構(gòu)之隊(duì)列(Quene)實(shí)例詳解
- C#使用隊(duì)列(Queue)解決簡單的并發(fā)問題
- C#多線程處理多個隊(duì)列數(shù)據(jù)的方法
- C#隊(duì)列Queue多線程用法實(shí)例
- C#隊(duì)列Queue用法實(shí)例分析
- C#使用foreach語句遍歷隊(duì)列(Queue)的方法
- c#隊(duì)列Queue學(xué)習(xí)示例分享
- C#數(shù)據(jù)結(jié)構(gòu)與算法揭秘五 棧和隊(duì)列
- C#實(shí)現(xiàn)順序隊(duì)列和鏈隊(duì)列的代碼實(shí)例
相關(guān)文章
C#和vb.net實(shí)現(xiàn)PDF 添加可視化和不可見數(shù)字簽名
本文通過C#程序代碼展示如何給PDF文檔添加可視化數(shù)字簽名和不可見數(shù)字簽名。文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08
C#關(guān)聯(lián)自定義文件類型到應(yīng)用程序并實(shí)現(xiàn)自動導(dǎo)入功能
今天通過本文給大家分享C#關(guān)聯(lián)自定義文件類型到應(yīng)用程序并實(shí)現(xiàn)自動導(dǎo)入功能,代碼中寫入了兩個注冊表,實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09

