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

C#中的集合用法分析

 更新時(shí)間:2014年10月23日 15:13:19   投稿:shichen2014  
這篇文章主要介紹了C#中的集合用法,實(shí)例形式分析了集合元素的定義、賦值、插入、移除等操作,需要的朋友可以參考下

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

【集合不同于數(shù)組,是一組可變類型的、可變數(shù)量的元素的組合,這些元素可能共享某些特征,需要以某種操作方式一起進(jìn)行操作。一般來講,為了便于操作這些元素的類型是相同的】

【集合與數(shù)組的區(qū)別:數(shù)組是連續(xù)的、同一類型數(shù)據(jù)的一塊區(qū)域,而集合可以是不連續(xù)的,多種數(shù)據(jù)類型】

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

1·集合的定義: 

復(fù)制代碼 代碼如下:
ArrayList al = new ArrayList();  //定義一個(gè) 集合,集合是一個(gè)類,在using System.Collections庫中,需要引用

2·集合的賦值:

復(fù)制代碼 代碼如下:
double fenshu = 0;

復(fù)制代碼 代碼如下:
al.Add(fenshu=double.Parse (Console .ReadLine ())); //如果是存數(shù)字,將來要比較大小,需要再添加的時(shí)候先轉(zhuǎn)換為數(shù)值類型再添加到集合里面,否則,會(huì)當(dāng)作字符串的編碼去比較大小,會(huì)出錯(cuò)!

(也可以用  .Add(); 進(jìn)行賦值  如:al.Add(2);  //括號(hào)內(nèi)是數(shù)據(jù)。第一個(gè)數(shù)據(jù)的索引號(hào)默認(rèn)是0,后面的類推)

3·在集合中插入數(shù)據(jù):

復(fù)制代碼 代碼如下:
al.insert( , ); //逗號(hào)前面的是索引號(hào),逗號(hào)后面的是數(shù)據(jù)(當(dāng)集合中有三個(gè)數(shù)據(jù),插入的索引號(hào)為1時(shí),則原為1索引號(hào)的數(shù)據(jù)將為2,后面的依次往后退一位)

4·移除集合中的數(shù)據(jù): 

復(fù)制代碼 代碼如下:
al.Remove();//括號(hào)內(nèi)填的是集合中要移除的數(shù)據(jù)(在移除中若集合中有兩個(gè)重復(fù)的數(shù) .Remove() 只移除第一次出現(xiàn)的數(shù))

復(fù)制代碼 代碼如下:
al.RemoveAt();//括號(hào)內(nèi)填的是集合中要移除的數(shù)據(jù)的索引號(hào)

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

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

7·在集合中求元素的索引號(hào):      (一定要注意數(shù)據(jù)類型是否匹配。如果返回值是-1,那么是沒有找到這個(gè)元素的索引號(hào))

復(fù)制代碼 代碼如下:
int s = al.IndexOf();       //括號(hào)中是要找的元素,這個(gè)元素第一次出現(xiàn)的索引號(hào)
int s1 = al.LastIndexOf();  //括號(hào)中是要找的元素,這個(gè)元素最后一次出現(xiàn)的索引號(hào)

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

9·獲取集合內(nèi)元素的個(gè)數(shù):

復(fù)制代碼 代碼如下:
Console.WriteLine(at.Count);//輸出集合的個(gè)數(shù)

10·復(fù)制集合中的元素?cái)?shù)據(jù),裝入新的集合當(dāng)中:

復(fù)制代碼 代碼如下:
ArrayList xal = new ArrayList();
xal = (ArrayList)al.Clone();

11·判斷一個(gè)集合里面是不是包含這個(gè)元素?cái)?shù)據(jù)返回bool值:

bool b = al.Contains();//括號(hào)內(nèi)為要查找是否集合包含的元素

—————特殊集合:Stack、Queue、哈希表(Hashtable)

Stack     堆的意思,先進(jìn)后出,后進(jìn)先出(堆沒有索引)

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

2·賦值:s.Push(1);       //將數(shù)據(jù)推入堆中

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

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

5· string tanchu = s.Peek().ToString();//只獲取最后進(jìn)去的那個(gè)數(shù)值,不移除

  string tanchu = s.Pop().ToString();//Pop是彈出并移除最后進(jìn)去的那個(gè)元素

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

7·Console.WriteLine(s.Count);//獲取集合內(nèi)元素的個(gè)數(shù)

Queue先進(jìn)先出,后進(jìn)后出

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

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

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

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

哈希表(Hashtable)    先進(jìn)后出,后進(jìn)先出     一個(gè)位置包含兩個(gè)值( , )前面是索引后面是元素

1·構(gòu)建 Hashtable ht = new Hashtable();

2· ht.Add(0,"aa");       // 向哈希表中添加鍵合值

3·ht.Remove(4);  //按照括號(hào)內(nèi)的Keys值移除

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

5· 輸出

復(fù)制代碼 代碼如下:
foreach (int i in ht.Keys)    //Keys表示索引
{
 Console.WriteLine(i);   //先進(jìn)后出,后進(jìn)先出
}

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

如果要同時(shí)輸出索引和元素呢?

 則:

復(fù)制代碼 代碼如下:
//利用枚舉輸出索引號(hào)和元素
IDictionaryEnumerator ide = ht.GetEnumerator();
while(ide.MoveNext ())
{
 Console.WriteLine(ide.Key +" "+ide.Value );
}

6·將哈希表轉(zhuǎn)換成Arraylist

復(fù)制代碼 代碼如下:
ArrayList al = new ArrayList();
foreach (string j in ht.Values )  //Values表示哈希表中的元素
{
 al.Add(j);
}

希望本文所述對(duì)大家的vc程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • C#用表達(dá)式樹構(gòu)建動(dòng)態(tài)查詢的方法

    C#用表達(dá)式樹構(gòu)建動(dòng)態(tài)查詢的方法

    這篇文章主要介紹了C#用表達(dá)式樹構(gòu)建動(dòng)態(tài)查詢的方法,幫助大家更好的理解和學(xué)習(xí)c#,感興趣的朋友可以了解下
    2020-12-12
  • unity實(shí)現(xiàn)虛擬搖桿控制Virtual Joystick

    unity實(shí)現(xiàn)虛擬搖桿控制Virtual Joystick

    這篇文章主要為大家詳細(xì)介紹了unity實(shí)現(xiàn)虛擬搖桿控制Virtual Joystick,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C#實(shí)現(xiàn)托盤程序并禁止多個(gè)應(yīng)用實(shí)例運(yùn)行的方法

    C#實(shí)現(xiàn)托盤程序并禁止多個(gè)應(yīng)用實(shí)例運(yùn)行的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)托盤程序并禁止多個(gè)應(yīng)用實(shí)例運(yùn)行的方法,涉及C#中NotifyIcon控件的使用及設(shè)置標(biāo)志位控制程序只運(yùn)行一個(gè)的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-11-11
  • WPF調(diào)用Matlab函數(shù)的方法

    WPF調(diào)用Matlab函數(shù)的方法

    這篇文章主要為大家詳細(xì)介紹了WPF調(diào)用Matlab函數(shù)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • c#冒泡排序算法示例

    c#冒泡排序算法示例

    這篇文章主要介紹了c#冒泡排序算法示例,需要的朋友可以參考下
    2014-04-04
  • C# 減少嵌套循環(huán)的兩種方法

    C# 減少嵌套循環(huán)的兩種方法

    最近在解決性能優(yōu)化的問題,看到了一堆嵌套循環(huán),四五層級(jí)的循環(huán)真的有點(diǎn)過分了,在數(shù)據(jù)量成萬,十萬級(jí)別的時(shí)候,真的非常影響性能。本文介紹了C# 減少嵌套循環(huán)的兩種方法,幫助各位選擇適合自己的優(yōu)化方案,優(yōu)化程序性能
    2021-06-06
  • C#實(shí)現(xiàn)的簡(jiǎn)單整數(shù)四則運(yùn)算計(jì)算器功能示例

    C#實(shí)現(xiàn)的簡(jiǎn)單整數(shù)四則運(yùn)算計(jì)算器功能示例

    這篇文章主要介紹了C#實(shí)現(xiàn)的簡(jiǎn)單整數(shù)四則運(yùn)算計(jì)算器功能,涉及C#界面布局、事件響應(yīng)及數(shù)值運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下
    2017-09-09
  • C#關(guān)于類的只讀只寫屬性實(shí)例分析

    C#關(guān)于類的只讀只寫屬性實(shí)例分析

    這篇文章主要介紹了C#關(guān)于類的只讀只寫屬性實(shí)例分析,對(duì)于初學(xué)者更好的理解類的只讀只寫屬性有一定的幫助,需要的朋友可以參考下
    2014-07-07
  • C# Winform按鈕中圖片實(shí)現(xiàn)左圖右字的效果實(shí)例

    C# Winform按鈕中圖片實(shí)現(xiàn)左圖右字的效果實(shí)例

    這篇文章主要給大家介紹了關(guān)于C# Winform按鈕中圖片實(shí)現(xiàn)左圖右字效果的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • C# 如何使用 Index 和 Range 簡(jiǎn)化集合操作

    C# 如何使用 Index 和 Range 簡(jiǎn)化集合操作

    這篇文章主要介紹了C# 如何使用 Index 和 Range 簡(jiǎn)化集合操作,幫助大家更好的理解和學(xué)習(xí)使用c#,感興趣的朋友可以了解下
    2021-02-02

最新評(píng)論