.NET中的Queue和Stack

来源:http://www.cnblogs.com/zhuyongblogs/archive/2016/01/26/5160815.html
-Advertisement-
Play Games

1.ArrayList類 ArrayList類主要用於對一個數組中的元素進行各種處理。在ArrayList中主要使用Add、Remove、RemoveAt、Insert四個方法對棧進行操作。Add方法用於將對象添加到ArrayList的結尾處;Remove方法用於從ArrayList中移除特定對象的...


1.ArrayList

ArrayList類主要用於對一個數組中的元素進行各種處理。在ArrayList中主要使用AddRemoveRemoveAtInsert四個方法對棧進行操作。Add方法用於將對象添加到ArrayList的結尾處;Remove方法用於從ArrayList中移除特定對象的第一個匹配項;RemoveAt方法用於移除ArrayList的指定索引處的元素;Insert方法用於將元素插入ArrayList的指定索引處。

示例將介紹如何創建一個ArrayList,如何添加項、移除項以用如何遍歷ArrayList。程式代碼如下:

 1 using System.Collections;//引入命名空間
 2 namespace _1
 3 {
 4     class ArrayListTest
 5     {
 6         static void Main(string[] args)
 7         {
 8             ArrayList arrlist = new ArrayList();//實例化一個ArrayList對象
 9             //使用Add方法向ArrayList中添加元素,將元素添加到ArrayList對象的末尾
10             arrlist.Add("蘋果");
11             arrlist.Add("香蕉");
12             arrlist.Add("葡萄");
13             foreach (int n in new int[3] { 0, 1, 2 })
14             {
15                 arrlist.Add(n);
16             }
17             //移除值為的第一個元素
18             arrlist.Remove(0);
19             //移除當前索引為的元素,即第個元素
20             arrlist.RemoveAt(3);
21             //在指定索引處添加一個元素
22             arrlist.Insert(1, "apple");
23             //遍歷ArrayList,並輸出所有元素
24             for (int i = 0; i < arrlist.Count; i++)
25             {
26                 Console.WriteLine(arrlist[i].ToString());
27             }
28         }
29     }
30 }

 

2Stack

Stack(堆棧)類主要實現了一個LIFOLast In First Out,後進先出)的機制。元素從棧的頂部插入(入棧操作),也從堆的頂部移除(出棧操作)。在Stack中主要使用PushPopPeek三個方法對棧進行操作。Push方法用於將對象插入Stack的頂部;Pop方法用於移除並返回位於Stack頂部的對象;Peek方法用於返回位於Stack頂部的對象但不將其移除。

示例將介紹如何創建一個Stack,如何添加項、移除項以用如何遍歷Stack。程式代碼如下:

 1 using System.Collections;//引入命名空間
 2 namespace _2
 3 {
 4     class StackTest
 5     {
 6         static void Main(string[] args)
 7         {
 8             //實例化Stack類的對象
 9             Stack stack = new Stack();
10             //入棧,使用Pust方法向Stack對向中添加元素
11             for (int i = 1; i < 6;i++)
12             {
13                 stack.Push(i);
14                 Console.WriteLine("{0}入棧",i);
15             }
16             //返回棧頂元素
17             Console.WriteLine ("當前棧頂元素為:{0}",stack.Peek().ToString ());
18             //出棧
19             Console.WriteLine("移除棧頂元素:{0}", stack.Pop().ToString());
20             //返回棧頂元素
21             Console.WriteLine("當前棧頂元素為:{0}", stack.Peek().ToString());
22             //遍歷棧
23             Console.WriteLine("遍歷棧");
24             foreach (int i in stack)
25             {
26                 Console.WriteLine(i);
27             }
28             //清空棧
29             while(stack .Count!=0)
30             {
31                 int s = (int)stack.Pop();
32                 Console.WriteLine("{0}出棧",s);
33             }
34         }
35     }
36 } 

 

3Queue

Queue(隊列)類主要實現了一個FIFOFirst In First Out,先進先出)的機制。元素在隊列的尾部插入(入隊操作),並從隊列的頭部移出(出隊操作)。在Queue中主要使用EnqueueDequeuePeek個方法對隊進行操作。Enqueue方法用於將對象添加到Queue的結尾處;Dequeue方法移除並返回位於Queue開始處的對象;Peek方法用於返回位於Queue開始處的對象但不將其移除。

示例將介紹如何創建一個Queue,如何添加項、移除項以用如何遍歷Queue。程式代碼如下:

 1 using System.Collections;//引入命名空間
 2 namespace _3
 3 {
 4     class QueueTest
 5     {
 6         static void Main(string[] args)
 7         {
 8             //實例化Queue類的對象
 9             Queue queue = new Queue();
10             //入棧,使用Pust方法向Stack對向中添加元素
11             for (int i = 1; i < 6; i++)
12             {
13                 queue .Enqueue(i);
14                 Console.WriteLine("{0}入隊", i);
15             }
16             //返回隊開始處的元素
17             Console.WriteLine("當前隊開始處元素為:{0}", queue.Peek().ToString());
18             //遍歷隊
19             Console.WriteLine("遍歷隊");
20             foreach (int i in queue)
21             {
22                 Console.WriteLine(i);
23             }
24             //清空棧
25             while (queue.Count != 0)
26             {
27                 int q = (int)queue.Dequeue ();
28                 Console.WriteLine("{0}出隊", q);
29             }
30         }
31     }
32 }

 

4Hashtable

Hashtable(哈希表)是一種鍵/值對集合,這些鍵/值對根據鍵的哈希代碼進行組織。在一個Hashtable中插入一對Key/Value時,它自動將Key值映射到Value,並允許獲取與一個指定的Key相關聯的value。在Hashtable中主要使用AddRemove兩個方法對哈希表進行操作。Add方法用於將帶有指定鍵和值的元素添加到Hashtable中;Remove方法用於從Hashtable中移除帶有指定鍵的元素。

示例將介紹如何創建一個Hashtable,如何添加項、移除項以用如何遍歷Hashtable。程式代碼如下:

 1 using System.Collections;//引入命名空間
 2  
 3 namespace _4
 4 {
 5     class HashtableTest
 6     {
 7         static void Main(string[] args)
 8         {
 9             //實例化Hashtable類的對象
10             Hashtable student=new Hashtable ();
11             //向Hashtable中添加元素
12             student.Add("S1001","Tom");
13             student.Add("S1002", "Jim");
14             student.Add("S1003", "Lily");
15             student.Add("S1004", "Lucy");
16             //遍歷Hashtable
17             foreach (DictionaryEntry element in student)
18             {
19                 string id = element.Key.ToString ();
20                 string name = element.Value.ToString ();
21                 Console.WriteLine("學生的ID:{0}   學生姓名:{1}",id,name);
22             }
23             //移除Hashtable中的元素
24             student.Remove("S1003");
25         }
26     }
27 }

說明:Hashtable不能包含重覆的key。如果調用Add 方法來添加一個keys數組中已有的key,就會拋出異常。為了避免這種情況,可以使用ContainsKey方法來測試哈希表中是否包含一個特定的Key

 

5SortedList

SortedList類也是鍵/值對的集合,但與哈希表不同的是這些鍵/值對是按鍵排序,並可以按照鍵和索引訪問。在SortedList中主要使用AddRemoveRemoveAt三個方法對SortedList進行操作。Add方法用於將帶有指定鍵和值的元素添加到SortedList中;Remove方法用於從SortedList中移除帶有指定鍵的元素;RemoveAt方法用於移除SortedList的指定索引處的元素。

示例將介紹如何創建一個SortedList,如何添加項、移除項以用如何遍歷SortedList。程式代碼如下:

 1 using System.Collections;//引入命名空間
 2  
 3 namespace _5
 4 {
 5     class SortedListTest
 6     {
 7         static void Main(string[] args)
 8         {
 9             //實例化SortedListTest類的對象
10             SortedList student = new SortedList();
11             //向SortedList中添加元素
12             student.Add("S1001", "Tom");
13             student.Add("S1003", "Jim");
14             student.Add("S1002", "Lily");
15             student.Add("S1004", "Lucy");
16             //遍歷SortedList
17             foreach (DictionaryEntry element in student)
18             {
19                 string id = element.Key.ToString();
20                 string name = element.Value.ToString();
21                 Console.WriteLine("學生的ID:{0}   學生姓名:{1}", id, name);
22             }
23             //移除SortedList中key為“S1003”的元素
24             student.Remove("S1003");
25             //移除SortedList中索引為“”的元素,即第一個元素
26             student.RemoveAt(0);
27         }
28     }
29 }

說明:同樣SortedList也不能包含重覆的key。而且使用foreach語句遍歷SortedList對象時,會返回DictionaryEntry對象。該對象將根據Key屬性,以排序後的順序返回。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一直以來被Linux的hostname和fqdn(Fully Qualified Domain Name)困惑了好久,今天專門抽時間把它們的使用細節弄清了。 一、設置hostname/fqdn 在Linux系統內設置hostname很簡單,如: $ hostname florian 如果...
  • Exynos4412時鐘域分類圖1:
  • 一、關閉SELinux安全增強型Linux(SELinux)的是一個Linux內核的功能,它提供支持訪問控制的安全政策保護機制。但是,SELinux帶來的附加安全性和使用複雜性上不成比例,性價比不高sed -i /SELINUX=enforcing/SELINUX=disabled/ /etc/se...
  • 前言只是作為一個shell的小小練習和日常統計用,瞎折騰的過程中也是摸到了獲取子shell返回值的幾種方法;肯定還有別的方法,跟進程間的通信相關,希望你能提出建議和補充,謝謝~ 完整程式: bash ! /bin/bash 檢查參數數量是否符合要求if [ $ ne 1 ]then echo Ho....
  • 一:預定義結構的 select 元素創建組合框(combobox)值固定寫死效果圖: 二:使用 javascript 創建組合框(combobox) 動態載入JS代碼:$('#cc').combobox({ url: 'test_list.aspx?id=1', ...
  • 本文要實現的功能是文件批量重命名,當選擇一個文件夾時,通過操作可以把文件夾下麵所有文件進行重命名。建立了HoverTreeBatch項目。然後定義文件夾信息:DirectoryInfo _TheFolder;//這裡是選擇文件夾並實例化_TheFolderFileInfo[] _files=null...
  • MVC 創建線程內的db單例
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...