1. 程式人生 > >C#中的集合用法分析

C#中的集合用法分析

這篇文章主要介紹了C#中的集合用法,例項形式分析了集合元素的定義、賦值、插入、移除等操作,需要的朋友可以參考下

本文例項講述了C#中的集合用法,分享給大家供大家參考。具體分析如下:

【集合不同於陣列,是一組可變型別的、可變數量的元素的組合,這些元素可能共享某些特徵,需要以某種操作方式一起進行操作。一般來講,為了便於操作這些元素的型別是相同的】

【集合與陣列的區別:陣列是連續的、同一型別資料的一塊區域,而集合可以是不連續的,多種資料型別】

【在集合中 foreach() 也是適用的】

1·集合的定義:  

程式碼如下: ArrayList al = new ArrayList();  //定義一個 集合,集合是一個類,在using System.Collections庫中,需要引用

2·集合的賦值:

程式碼如下 double fenshu = 0; 程式碼如下: al.Add(fenshu=double.Parse (Console .ReadLine ())); //如果是存數字,將來要比較大小,需要再新增的時候先轉換為數值型別再新增到集合裡面,否則,會當作字串的編碼去比較大小,會出錯!

(也可以用  .Add(); 進行賦值  如:al.Add(2);  //括號內是資料。第一個資料的索引號預設是0,後面的類推)

3·在集合中插入資料:

程式碼如下: al.insert( , ); //逗號前面的是索引號,逗號後面的是資料(當集合中有三個資料,插入的索引號為1時,則原為1索引號的資料將為2,後面的依次往後退一位)

4·移除集合中的資料: 

程式碼如下: al.Remove();//括號內填的是集合中要移除的資料(在移除中若集合中有兩個重複的數 .Remove() 只移除第一次出現的數) 程式碼如下: al.RemoveAt();//括號內填的是集合中要移除的資料的索引號

5· .count;//檢視集合的長度,返回int型

6·集合中的排序: .Sort();//這是升序排序,降序排序的話要在升序排序方法後用翻轉(翻轉———   .Reverse();)

7·在集合中求元素的索引號:      (一定要注意資料型別是否匹配。如果返回值是-1,那麼是沒有找到這個元素的索引號)

程式碼如下: int s = al.IndexOf();       //括號中是要找的元素,這個元素第一次出現的索引號
int s1 = al.LastIndexOf();  //括號中是要找的元素,這個元素最後一次出現的索引號

8·清空集合:  .Clear();

9·獲取集合內元素的個數:

程式碼如下: Console.WriteLine(at.Count);//輸出集合的個數

10·複製集合中的元素資料,裝入新的集合當中:

程式碼如下: ArrayList xal = new ArrayList();
xal = (ArrayList)al.Clone();

11·判斷一個集合裡面是不是包含這個元素資料返回bool值:

bool b = al.Contains();//括號內為要查詢是否集合包含的元素

—————特殊集合:Stack、Queue、雜湊表(Hashtable)

Stack     堆的意思,先進後出,後進先出(堆沒有索引)

1·構建 Stack  s=new.Stack();

2·賦值:s.Push(1);       //將資料推入堆中

3·輸出:Console.WriteLine(s.Pop());

4·清空集合: .clear();

5· string tanchu = s.Peek().ToString();//只獲取最後進去的那個數值,不移除

  string tanchu = s.Pop().ToString();//Pop是彈出並移除最後進去的那個元素

6· Stack fuzhi = (Stack)s.Clone();//賦值集合

7·Console.WriteLine(s.Count);//獲取集合內元素的個數

Queue先進先出,後進後出

1·構建:Queue q = new Queue();

2·int chu = int.Parse(q.Dequeue ().ToString ());//獲取第一個進去的元素,並從集合中移除

3·int zhi = int.Parse(q.Peek ().ToString ());//讀取第一個進去的元素,不移除

4·bool d = q.Contains(5);//看集合中是否包含括號中的元素,返回bool值

雜湊表(Hashtable)    先進後出,後進先出     一個位置包含兩個值( , )前面是索引後面是元素

1·構建 Hashtable ht = new Hashtable();

2· ht.Add(0,"aa");       // 向雜湊表中新增鍵合值

3·ht.Remove(4);  //按照括號內的Keys值移除

4·Console.WriteLine(ht.Contains (4));//判斷是否包含某個鍵

5· 輸出

程式碼如下: foreach (int i in ht.Keys)    //Keys表示索引
{
 Console.WriteLine(i);   //先進後出,後進先出
}

foreach (int i in ht..Values)//.Values表示元素
{
 Console.WriteLine(i);   //先進後出,後進先出
}

如果要同時輸出索引和元素呢?

 則:

程式碼如下: //利用列舉輸出索引號和元素
IDictionaryEnumerator ide = ht.GetEnumerator();
while(ide.MoveNext ())
{
 Console.WriteLine(ide.Key +" "+ide.Value );
}

6·將雜湊錶轉換成Arraylist

程式碼如下: ArrayList al = new ArrayList();
foreach (string j in ht.Values )  //Values表示雜湊表中的元素
{
 al.Add(j);
}