国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C#棧和隊列的簡介,算法與應用簡單實例

2020-01-24 00:13:43
字體:
來源:轉載
供稿:網友

堆棧(Stack)

代表了一個后進先出的對象集合。當您需要對各項進行后進先出的訪問時,則使用堆棧。當您在列表中添加一項,稱為推入元素,當您從列表中移除一項時,稱為彈出元素。

常用方法:

public virtual void Clear();

從 Stack 中移除所有的元素。

public virtual bool Contains( object obj );

判斷某個元素是否在 Stack 中。

public virtual object Peek();

返回在 Stack 的頂部的對象,但不移除它。

public virtual object Pop();

移除并返回在 Stack 的頂部的對象。

public virtual void Push( object obj );

向 Stack 的頂部添加一個對象。

public virtual object[] ToArray();

復制 Stack 到一個新的數組中。

========================================================

隊列(Queue)

代表了一個先進先出的對象集合。當您需要對各項進行先進先出的訪問時,則使用隊列。當您在列表中添加一項,稱為入隊,當您從列表中移除一項時,稱為出隊。

常用方法:

public virtual void Clear();

從 Queue 中移除所有的元素。

2 public virtual bool Contains( object obj );

判斷某個元素是否在 Queue 中。

public virtual object Dequeue();

移除并返回在 Queue 的開頭的對象。

public virtual void Enqueue( object obj );

向 Queue 的末尾添加一個對象。

public virtual object[] ToArray();

復制 Queue 到一個新的數組中。

public virtual void TrimToSize();

設置容量為 Queue 中元素的實際個數。

=========================================================

簡單實例:

編程判斷一個字符串是否是回文。回文是指一個字符序列以中間字符為基準兩邊字符完全相同,如字符序列“ACBDEDBCA”是回文。

算法思想:

判斷一個字符序列是否是回文,就是把第一個字符與最后一個字符相比較,第二個字符與倒數第二個字符比較,依次類推,第 i 個字符與第 n-i個字符比較。如果每次比較都相等,則為回文,如果某次比較不相等,就不是回文。因此,可以把字符序列分別入隊列和棧,然后逐個出隊列和出棧并比較出隊列的字符和出棧的字符是否相等,若全部相等則該字符序列就是回文,否則就不是回文。

using System;using System.Collections.Generic;namespace 棧和隊列舉例{ 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();  } }}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。如果你想了解更多相關內容請查看下面相關鏈接

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 资阳市| 左权县| 荆州市| 新安县| 修文县| 襄垣县| 揭东县| 芒康县| 鄯善县| 西和县| 苏尼特左旗| 三原县| 焉耆| 巴彦淖尔市| 沂水县| 凌云县| 阿拉善左旗| 合阳县| 滦南县| 隆回县| 陈巴尔虎旗| 叙永县| 建始县| 涿鹿县| 临清市| 泸溪县| 若尔盖县| 略阳县| 高陵县| 盐池县| 保山市| 大理市| 丽江市| 横峰县| 青州市| 呼伦贝尔市| 比如县| 乌拉特前旗| 丰都县| 科技| 鄱阳县|