欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#中的集合用法分析

程序员文章站 2023-12-16 09:50:04
本文实例讲述了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);
}

希望本文所述对大家的vc程序设计有所帮助。

上一篇:

下一篇: