数组和集合对象.ppt

上传人:啊飒飒 文档编号:13245608 上传时间:2021-12-19 格式:PPT 页数:37 大小:614.50KB
返回 下载 相关 举报
数组和集合对象.ppt_第1页
第1页 / 共37页
数组和集合对象.ppt_第2页
第2页 / 共37页
数组和集合对象.ppt_第3页
第3页 / 共37页
数组和集合对象.ppt_第4页
第4页 / 共37页
数组和集合对象.ppt_第5页
第5页 / 共37页
点击查看更多>>
资源描述

《数组和集合对象.ppt》由会员分享,可在线阅读,更多相关《数组和集合对象.ppt(37页珍藏版)》请在三一文库上搜索。

1、第六节,数组和集合对象,目标,数组的使用使用System.Array 对象理解集合对象的特点和优点使用System.ArrayList 对象使用哈希表对象,数组,数组是一种包含若干变量的数据结构,这些变量都可以通过计算索引进行访问。数组中的数组的元素具有相同的类型。数组有一个“秩”。数组的秩又称为数组的维度。“秩”为1的数组称为一维数组。“秩”大于1的数组称为多维数组。维度大小确定的多维数组通常称为两维数组、三维数组等。,声明数组,声明数组时,方括号()必须跟在类型后面,而不是标识符后面。在C#中,将方括号放在标识符后是不合法的语法。C#支持一维数组、多维数组(矩形数组)和数组的数组(交错的数

2、组)。,一维数组:intarrayname;多维数组:int,arrayname;数组的数组(交错的):intarrayname;注意:声明数组并不实际创建它们。在C#中,数组是对象,必须进行实例化。,数组示例,usingSystem;classTestArraypublicstaticvoidMain()/声明一个整型一维数组的引用,变且在堆中分配连续5个整型变量的空间。intnumbers=newint5;/声明一个二维字符串数组的引用string,names=newstring5,4;/数组的数组,相当声明了包含5个byte型一维数组的引用变量的一维数组长度为5bytescores=ne

3、wbyte5;/为每个btye型一维数组实例化for(inti=0;iscores.Length;i+)scoresi=newbytei+3;/非矩形的for(inti=0;iscores.Length;i+)Console.WriteLine(Lengthofrow0is1,i,scoresi.Length);,初始化数组,C#通过将初始值括在大括号()内为在声明时初始化数组提供了简单而直接了当的方法。,一维数组intnumbers=newint 51,2,3,4,5;stringnames=newstring 3Matt,Joanne,Robert;可省略数组的大小intnumbers=n

4、ewint 1,2,3,4,5;stringnames=newstring Matt,Joanne,Robert;如果提供了初始值设定项,则还可以省略new运算符intnumbers=1,2,3,4,5;stringnames=Matt,Joanne,Robert;,初始化数组,C#通过将初始值括在大括号()内为在声明时初始化数组提供了简单而直接了当的方法。,多维数组int,numbers=newint 3,21,2,3,4,5,6;string,siblings=newstring 2,2Mike,Amy,Mary,Albert;可省略数组的大小int,numbers=newint ,1,2

5、,3,4,5,6;string,siblings=newstring ,Mike,Amy,Mary,Albert;如果提供了初始值设定项,则还可以省略new运算符int,numbers=1,2,3,4,5,6;string,siblings=Mike,Amy,Mary,Albert;,初始化数组,C#通过将初始值括在大括号()内为在声明时初始化数组提供了简单而直接了当的方法。,交错的数组(数组的数组)intnumbers=newint 2newint2,3,4,newint5,6,7,8,9;可省略第一个数组的大小intnumbers=newintnewint2,3,4,newint5,6,7

6、,8,9;或intnumbers=newint2,3,4,newint5,6,7,8,9;,访问数组成员,访问数组成员可以直接进行,类似于在C/C+中访问数组成员。,下面的代码创建一个名为numbers的数组,然后向该数组的第五个元素赋以5:intnumbers=10,9,8,7,6,5,4,3,2,1,0;numbers4=5;下面的代码声明一个多维数组,并向位于1,1的成员赋以5:int,numbers=1,2,3,4,5,6,7,8,9,10;numbers1,1=5;下面声明一个一维交错数组,它包含两个元素。第一个元素是两个整数的数组,第二个元素是三个整数的数组:intnumbers=

7、newintnewint1,2,newint3,4,5 ;下面的语句向第一个数组的第一个元素赋以58,向第二个数组的第二个元素赋以667:numbers00=58;numbers11=667;,对数组使用foreach,C#还提供foreach语句。该语句提供一种简单、明了的方法来循环访问数组的元素。,intnumbers=4,5,6,1,2,3,-2,-1,0;foreach(intiinnumbers)System.Console.WriteLine(i);,对数组使用foreach,C#还提供foreach语句。该语句提供一种简单、明了的方法来循环访问数组的元素。,int,numbers

8、=newint 3,29,99,3,33,5,55;foreach(intiinnumbers)Console.Write(0,i);,System.Array类,在C#中,数组实际上是对象。System.Array是所有数组类型的抽象基类型。System. Array提供创建、操作、搜索和排序数组的方法,因而在公共语言运行库中用作所有数组的基类。所有数组都可以使用System. Array的属性和方法。,常用属性和方法,Length属性 表示数组所有维数中元素的总数。intnumber=1,2,3,4;number.Length的值为4; Rank属性 表示数组中的维数。string,nam

9、es=newstring5,4;names.Rank的值为2。,常用属性和方法,Sort方法 对一维数组排序。它是Array类的静态方法.stringname= newstring xi,ang,zhang,chun;Array.Sort(name);foreach( stringsinname)Console.WriteLine(s);Reverse方法 反转一维数组Array.Reverse(name);其值为:chun,zhang,ang,xi,常用属性和方法,GetLowerBound与GetUpperBound方法 数组指定维度的下限与上限int,number= newint 4,3

10、,2 1,2,2,3,3,4, 4,5,5,6,6,7, 7,8,8,9,9,10, 10,11,11,12,12,13 ;for ( inti=number.GetLowerBound(0);i=number.GetUpperBound(0);i+)for ( intj=number.GetLowerBound(1);j=number.GetUpperBound(1);j+)for( intk=number.GetLowerBound(2);k=number.GetUpperBound(2);k+)Console.WriteLine(“number0,1,2=3”,i,j,k,numberi

11、,j,k);Clear方法 重新初始化数组中所有的元素将数组中的一系列元素设置为零、false或空引用.,常用属性和方法,CreateInstance 方法创建数组 Array obj = Array.CreateInstance(typeof(string),10);,static void Main(string args) /构建 objNames 数组 Array objNames = Array.CreateInstance(typeof(string),5); /初始化值 objNames.SetValue(“A,0); objNames.SetValue(“B,1); objNa

12、mes.SetValue(“C,2); objNames.SetValue(“D,3); objNames.SetValue(“E,4); Console.WriteLine(“数组值); for(int ctr = 0 ; ctr 5; ctr+) Console.WriteLine(“元素 0: 1,ctr+1,objNames.GetValue(ctr); ,System.Collections 简介,System.Collections 命名空间包含接口和类,这些接口和类定义各种对象(如列表、队列、位数组、哈希表和字典)的集合。,哈希表(Hashtable)简述,Hashtable是S

13、ystem.Collections命名空间提供的一个容器用于处理和表现类似key/value的键值对key通常可用 来快速查找,同时key是区分大小写;value用于存储对应于key的值。Hashtable中key/value键值对均为object类型,所以 Hashtable可以支持任何类型的key/value键值对.,哈希表的简单操作,在哈希表中添加一个key/value键值对:HashtableObject.Add(key,value);在哈希表中去除某个key/value键值对:HashtableObject.Remove(key);从哈希表中移除所有元素:HashtableObjec

14、t.Clear(); 判断哈希表是否包含特定键key:HashtableObject.Contains(key);,using System;using System.Collections; /使用Hashtable时,必须引入这个命名空间class hashtablepublic static void Main()Hashtable ht=new Hashtable(); /创建一个Hashtable实例ht.Add(“E”,“e”);/添加key/value键值对ht.Add(“A”,“a”);ht.Add(“C”,“c”);ht.Add(“B”,“b”);string s=(stri

15、ng)ht“A”;if(ht.Contains(“E”) /判断哈希表是否包含特定键,其返回值为true或falseConsole.WriteLine(“the E key:exist”);ht.Remove(“C”);/移除一个key/value键值对Console.WriteLine(ht“A”); /此处输出aht.Clear(); /移除所有元素Console.WriteLine(htA); /此处将不会有任何输出,遍历哈希表,遍历哈希表需要用到DictionaryEntry Object:for(DictionaryEntry de in ht) /ht为一个Hashtable实例C

16、onsole.WriteLine(de.Key); /de.Key对应于key/value键值对keyConsole.WriteLine(de.Value); /de.Key对应于key/value键值对value,对哈希表进行排序,对哈希表进行排序在这里的定义是对key/value键值对中的key按一定规则重新排列但是实际上这个定义是不能实现的,因为我们无法直接在Hashtable进行对key进行重新排列如果需要Hashtable提供某种规则的输出,可以采用一种变通的做法:,ArrayList akeys=new ArrayList(ht.Keys); /别忘了导入System.Collec

17、tionsakeys.Sort(); /按字母顺序进行排序for(string skey in akeys)Console.Write(skey + :);Console.WriteLine(htskey); /排序后输出,ArrayList 类,Array 类的容量或元素数是固定的,而 ArrayList 类的容量可以根据需要动态扩展。通过设置ArrayList.Capacity 的值可以重新分配内存和复制元素使用 ArrayList 提供的方法可以同时添加、插入或移除一个范围内的元素,优点支持自动改变大小的功能可以灵活的插入元素可以灵活的删除元素局限性跟一般的数组比起来,速度上差些,添加元

18、素,将对象添加到ArrayList的结尾处ArrayList aList=new ArrayList();aList.Add(a);aList.Add(b);aList.Add(c);aList.Add(d);aList.Add(e);内容为: abcde,添加元素,将元素插入ArrayList的指定索引处ArrayList aList=new ArrayList();aList.Add(a);aList.Add(b);aList.Add(c);aList.Add(d);aList.Add(e);aList.Insert(0,aa);结果为: aaabcde,添加元素,将集合中的某个元素插入A

19、rrayList的指定索引处ArrayList aList=new ArrayList();aList.Add(a);aList.Add(b);aList.Add(c);aList.Add(d);aList.Add(e);ArrayList list2=new ArrayList();list2.Add(tt);list2.Add(ttt);aList.InsertRange(2,list2);结果为: abtttttcde,删除,从ArrayList中移除特定对象的第一个匹配项,注意是第一个ArrayList aList=new ArrayList();aList.Add(a);aList.

20、Add(b);aList.Add(c);aList.Add(d);aList.Add(e);aList.Remove(a);结果为: bcde,删除,移除ArrayList的指定索引处的元素aList.Add(a);aList.Add(b);aList.Add(c);aList.Add(d);aList.Add(e);aList.RemoveAt(0);结果为: bcde,删除,从ArrayList中移除一定范围的元素。Index表示索引,count表示从索引处开始的数目aList.Add(a);aList.Add(b);aList.Add(c);aList.Add(d);aList.Add(

21、e);aList.RemoveRange(1,3);结果为: ae,删除,从ArrayList中移除一定范围的元素。Index表示索引,count表示从索引处开始的数目aList.Add(a);aList.Add(b);aList.Add(c);aList.Add(d);aList.Add(e);aList.RemoveRange(1,3);结果为: ae 从ArrayList中移除所有元素aList.Clear ();,排序,对ArrayList或它的一部分中的元素进行排序。ArrayList aList=new ArrayList();aList.Add(e);aList.Add(a);a

22、List.Add(b);aList.Add(c);aList.Add(d);DropDownList1.DataSource=aList; /DropDownList DropDownList1;DropDownList1.DataBind();结果为: eabcd aList.Sort(); /排序DropDownList2.DataSource=aList; /DropDownList DropDownList2;DropDownList2.DataBind();结果为: abcde,反转,将ArrayList或它的一部分中元素的顺序反转。ArrayList aList=new Array

23、List();aList.Add(a);aList.Add(b);aList.Add(c);aList.Add(d);aList.Add(e);aList.Reverse(); /反转DropDownList1.DataSource=aList; /DropDownList DropDownList1;DropDownList1.DataBind();结果为:edcba,查找,返回ArrayList或它的一部分中某个值的第一个匹配项的从零开始的索引。没找到返回-1。ArrayList aList=new ArrayList();aList.Add(a);aList.Add(b);aList.A

24、dd(c);aList.Add(d);aList.Add(e);intnIndex=aList.IndexOf(“a”); /0nIndex=aList.IndexOf(“p”); /没找到,-1,查找,返回ArrayList或它的一部分中某个值的最后一个匹配项的从零开始的索引。ArrayList aList=new ArrayList();aList.Add(a);aList.Add(b);aList.Add(a); /同0aList.Add(d);aList.Add(e);intnIndex=aList.LastIndexOf(a); /值为2而不是0,获取ArrayList中实际包含的元

25、素数,Capacity是ArrayList可以存储的元素数。Count是ArrayList中实际包含的元素数。Capacity总是大于或等于Count。如果在添加元素时,Count超过Capacity,则该列表的容量会通过自动重新分配内部数组加倍。如果Capacity的值显式设置,则内部数组也需要重新分配以容纳指定的容量。如果Capacity被显式设置为0,则公共语言运行库将其设置为默认容量。默认容量为16。在调用Clear后,Count为0,而此时Capacity切是默认容量16,而不是0,将容量设置为ArrayList中元素的实际数量,如果不向列表中添加新元素,则此方法可用于最小化列表的内

26、存系统开销。若要完全清除列表中的所有元素,请在调用TrimToSize之前调用Clear方法。截去空ArrayList会将ArrayList的容量设置为默认容量,而不是零。,ArrayList aList= new ArrayList();aList.Add(a);aList.Add(b);aList.Add(c);aList.Add(d);aList.Add(e); /Count=5,Capacity=16;aList.TrimToSize(); /Count=Capacity=5;,总结,多数编程语言都提供数组这种数据结构,用以存储属于相同类型的多个数据元素可以使用 Array 类的 CreateInstance 方法来创建Array对象,也可以直接定义数组对象集合可用于管理在运行时动态创建的元素项 System.Collections 命名空间提供一组接口和类,让用户可以对一组数据元素执行各种集合操作用户可以通过 HashTable 类将数据、键值作为一组来存储,这些数据是根据键值进行组织的Array 类属于 System 命名空间,而 ArrayList 类属于 System.Collections 命名空间ArrayList在Array的基础上提供了动态的特性,练习,员工管理系统和学生管理系统用ArrayList实现,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 科普知识


经营许可证编号:宁ICP备18001539号-1