欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#棧和隊(duì)列的簡(jiǎn)介,算法與應(yīng)用簡(jiǎn)單實(shí)例

 更新時(shí)間:2018年10月25日 09:24:52   作者:Czhenya  
今天小編就為大家分享一篇關(guān)于C#棧和隊(duì)列的簡(jiǎn)介,算法與應(yīng)用簡(jiǎn)單實(shí)例,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧

堆棧(Stack)

代表了一個(gè)后進(jìn)先出的對(duì)象集合。當(dāng)您需要對(duì)各項(xiàng)進(jìn)行后進(jìn)先出的訪問時(shí),則使用堆棧。當(dāng)您在列表中添加一項(xiàng),稱為推入元素,當(dāng)您從列表中移除一項(xiàng)時(shí),稱為彈出元素。

常用方法:

public virtual void Clear();

從 Stack 中移除所有的元素。

public virtual bool Contains( object obj );

判斷某個(gè)元素是否在 Stack 中。

public virtual object Peek();

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

public virtual object Pop();

移除并返回在 Stack 的頂部的對(duì)象。

public virtual void Push( object obj );

向 Stack 的頂部添加一個(gè)對(duì)象。

public virtual object[] ToArray();

復(fù)制 Stack 到一個(gè)新的數(shù)組中。

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

隊(duì)列(Queue)

代表了一個(gè)先進(jìn)先出的對(duì)象集合。當(dāng)您需要對(duì)各項(xiàng)進(jìn)行先進(jìn)先出的訪問時(shí),則使用隊(duì)列。當(dāng)您在列表中添加一項(xiàng),稱為入隊(duì),當(dāng)您從列表中移除一項(xiàng)時(shí),稱為出隊(duì)。

常用方法:

public virtual void Clear();

從 Queue 中移除所有的元素。

2 public virtual bool Contains( object obj );

判斷某個(gè)元素是否在 Queue 中。

public virtual object Dequeue();

移除并返回在 Queue 的開頭的對(duì)象。

public virtual void Enqueue( object obj );

向 Queue 的末尾添加一個(gè)對(duì)象。

public virtual object[] ToArray();

復(fù)制 Queue 到一個(gè)新的數(shù)組中。

public virtual void TrimToSize();

設(shè)置容量為 Queue 中元素的實(shí)際個(gè)數(shù)。

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

簡(jiǎn)單實(shí)例:

編程判斷一個(gè)字符串是否是回文?;匚氖侵敢粋€(gè)字符序列以中間字符為基準(zhǔn)兩邊字符完全相同,如字符序列“ACBDEDBCA”是回文。

算法思想:

判斷一個(gè)字符序列是否是回文,就是把第一個(gè)字符與最后一個(gè)字符相比較,第二個(gè)字符與倒數(shù)第二個(gè)字符比較,依次類推,第 i 個(gè)字符與第 n-i個(gè)字符比較。如果每次比較都相等,則為回文,如果某次比較不相等,就不是回文。因此,可以把字符序列分別入隊(duì)列和棧,然后逐個(gè)出隊(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é)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

相關(guān)文章

  • C#入門之結(jié)構(gòu)類型Struct

    C#入門之結(jié)構(gòu)類型Struct

    這篇文章介紹了C#入門之結(jié)構(gòu)類型Struct,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • C#7.0中新特性匯總

    C#7.0中新特性匯總

    C#7.0 增加了許多新功能,并專注于數(shù)據(jù)消費(fèi),簡(jiǎn)化代碼和性能的改善。接下來通過本文給大家介紹C#7.0中新特性匯總,需要的朋友可以參考下
    2016-08-08
  • C# null 合并運(yùn)算符??(雙問號(hào))使用示例

    C# null 合并運(yùn)算符??(雙問號(hào))使用示例

    這篇文章主要介紹了C# null 合并運(yùn)算符??(雙問號(hào))使用示例,?? 運(yùn)算符稱作 null 合并運(yùn)算符。如果此運(yùn)算符的左操作數(shù)不為 null,則此運(yùn)算符將返回左操作數(shù);否則返回右操作數(shù),需要的朋友可以參考下
    2014-06-06
  • C#域名解析簡(jiǎn)單實(shí)現(xiàn)方法

    C#域名解析簡(jiǎn)單實(shí)現(xiàn)方法

    這篇文章主要介紹了C#域名解析簡(jiǎn)單實(shí)現(xiàn)方法,可實(shí)現(xiàn)針對(duì)域名解析顯示出主機(jī)名、IP地址、別名等功能,需要的朋友可以參考下
    2015-07-07
  • 事務(wù)在c#中的使用

    事務(wù)在c#中的使用

    這篇文章介紹了事務(wù)在c#中的使用,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • 一文帶你吃透C#中面向?qū)ο蟮南嚓P(guān)知識(shí)

    一文帶你吃透C#中面向?qū)ο蟮南嚓P(guān)知識(shí)

    這篇文章主要為大家詳細(xì)介紹了C#中面向?qū)ο蟮南嚓P(guān)知識(shí),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C#有一定的幫助,需要的小伙伴可以參考一下
    2023-02-02
  • C#中Timer實(shí)現(xiàn)Tick使用精度的問題

    C#中Timer實(shí)現(xiàn)Tick使用精度的問題

    這篇文章主要介紹了C#中Timer實(shí)現(xiàn)Tick使用精度的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Unity?UGUI的EventSystem事件系統(tǒng)組件介紹使用

    Unity?UGUI的EventSystem事件系統(tǒng)組件介紹使用

    這篇文章主要為大家介紹了Unity?UGUI的EventSystem事件系統(tǒng)組件介紹使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • c# winform多線程的小例子

    c# winform多線程的小例子

    c# winform多線程的小例子,需要的朋友可以參考一下
    2013-04-04
  • 關(guān)于C# 類的封裝詳情

    關(guān)于C# 類的封裝詳情

    C#中可使用類來達(dá)到數(shù)據(jù)封裝的效果,這樣就可以使數(shù)據(jù)與方法封裝成單一元素,以便于通過,接下來小編將為大家詳細(xì)介紹,需要的朋友可以參考一下
    2021-10-10

最新評(píng)論