本文實例講述了C#中的集合用法,分享給大家供大家參考。具體分析如下:
【集合不同于數組,是一組可變類型的、可變數量的元素的組合,這些元素可能共享某些特征,需要以某種操作方式一起進行操作。一般來講,為了便于操作這些元素的類型是相同的】
【集合與數組的區別:數組是連續的、同一類型數據的一塊區域,而集合可以是不連續的,多種數據類型】
【在集合中 foreach() 也是適用的】
1?集合的定義:
2?集合的賦值:
(也可以用 .Add(); 進行賦值 如:al.Add(2); //括號內是數據。第一個數據的索引號默認是0,后面的類推)
3?在集合中插入數據:
4?移除集合中的數據:
5? .count;//查看集合的長度,返回int型
6?集合中的排序: .Sort();//這是升序排序,降序排序的話要在升序排序方法后用翻轉(翻轉――― .Reverse();)
7?在集合中求元素的索引號: (一定要注意數據類型是否匹配。如果返回值是-1,那么是沒有找到這個元素的索引號)
8?清空集合: .Clear();
9?獲取集合內元素的個數:
10?復制集合中的元素數據,裝入新的集合當中:
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..Values)//.Values表示元素
{
Console.WriteLine(i); //先進后出,后進先出
}
如果要同時輸出索引和元素呢?
則:
6?將哈希表轉換成Arraylist
希望本文所述對大家的vc程序設計有所幫助。
新聞熱點
疑難解答