【集合不同于数组,是一组可变类型的、可变数量的元素的组合,这些元素可能共享某些特征,需要以某种操作方式一起进行操作。一般来讲,为了便于操作这些元素的类型是相同的】

【集合与数组的区别:数组是连续的、同一类型数据的一块区域,而集合可以是不连续的,多种数据类型】

【在集合中 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·在集合中插入数据:  .insert( , ); //逗号前面的是索引号,逗号后面的是数据(当集合中有三个数据,插入的索引号为1时,则原为1索引号的数据将为2,后面的依次往后退一位)

4·移除集合中的数据:  .Remove();//括号内填的是集合中要移除的数据(在移除中若集合中有两个重复的数 .Remove() 只移除第一次出现的数)

.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);
            }

C#中的集合的更多相关文章

  1. Java 中的集合接口——List、Set、Map

    Java 中的集合接口——List.Set.Map 什么叫集合:集合就是Java API所提供的一系列类的实例,可以用于动态存放多个对象.这跟我们学过的数组差不多,那为什么我们还要学集合,我们看看数组 ...

  2. C#中的集合有几种?

    C#中的集合有几种? Array ArrayList List<T> Stack<T> Queue<T> Dictionary<K,V> HashTab ...

  3. Java中的集合框架

    概念与作用 集合概念 现实生活中:很多事物凑在一起 数学中的集合:具有共同属性的事物的总体 java中的集合类:是一种工具类,就像是容器,储存任意数量的具有共同属性的对象 在编程时,常常需要集中存放多 ...

  4. 实现java 中 list集合中有几十万条数据,每100条为一组取出

    解决"java 中 list集合中有几十万条数据,每100条为一组取出来如何实现,求代码!!!"的问题. 具体解决方案如下: /** * 实现java 中 list集合中有几十万条 ...

  5. 线程高级应用-心得8-java5线程并发库中同步集合Collections工具类的应用及案例分析

    1.  HashSet与HashMap的联系与区别? 区别:前者是单列后者是双列,就是hashmap有键有值,hashset只有键: 联系:HashSet的底层就是HashMap,可以参考HashSe ...

  6. 14.python中的集合

    什么是集合?正如其字面的意思,一堆东西集中合并到一起.乍一听貌似和容器没什么差别,嗯,好吧,集合也算是一种容器. 在学习这个容器有什么不同之前,先看看集合是如何创建的: a = set() #可变集合 ...

  7. java中对集合对象list的几种循环访问

    java中对集合对象list的几种循环访问的总结如下 1 经典的for循环 public static void main(String[] args) { List<String> li ...

  8. 菜鸟日记之 java中的集合框架

    java中的集合框架图 如图所示:java中的集合分为两种Collection和Map两种接口 可分为Collection是单列集合和Map的双列集合 Collection单列集合:继承了Iterat ...

  9. C#与java中的集合区别

    集合一般的操作       插入: add       删除: remove       查找: contains,remove java中的集合 注意哪些是接口,哪些是实现类 使用集合的时候 1. ...

随机推荐

  1. 高级C++开发工程师综合测试题(风林火山)

    题目要求:代码要求能够直接编译运行 1.       请实现一个函数:凑14:输入很多个整数(1<=数值<=13),任意两个数相加等于14就可以从数组中删除这两个数,求剩余数(按由小到大排 ...

  2. 剑指OFFER之二叉树中和为某一值的路径(九度OJ1368)

    题目描述: 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 输入: 每个测试案例包括n+1行: 第一行为2 ...

  3. 有如下Student 对象,  private String name;       private int age;       private int score;   private String classNum;  其中,classNum

    package homework003; import java.util.ArrayList; import java.util.List; public class Text { public s ...

  4. 9 个让 JavaScript 调试更简单的 Console 命令

    一.显示信息的命令 <!DOCTYPE html> <html> <head> <title>常用console命令</title> < ...

  5. android获取mac地址方法

    http://www.cnblogs.com/xioapingguo/p/4037513.html 网上找的,记录一下 public static String getMacAdress(){ Wif ...

  6. AS问题解决系列3—iCCP: Not recognizing known sRGB profile

    http://my.oschina.net/1pei/blog/479162 摘要 本文解决了Android Studio 1.2.2下编译期间出现的libpng warning: iCCP: Not ...

  7. UITableview 中获取非选中的cell

    实现效果如图: 在cell中有一个button,选中cell改变button的选择状态 yes,选中另外一个cell,别的cell中的button选择状态变成false. //获取当前可显示的cell ...

  8. 连载:面向对象葵花宝典:思想、技巧与实践(32) - LSP原则

    LSP是唯一一个以人名命名的设计原则,并且作者还是一个"女博士"  ======================================================== ...

  9. 使用RecyclerView写树形结构的TreeRecyclerView

    简单介绍 android是不提供树形控件的,假设须要使用树形控件.我们应该怎么做呢? 先看效果 上图是一个明显的树形结构 实现原理 在逻辑上,它们是包括关系.数据结构上是多叉树,这是毋庸置疑的. 可是 ...

  10. CircularProgressBar

    https://github.com/semicoder/CircularProgressBar https://github.com/amurani/MeterView