c#之数组,集合和哈希表

一、数组

数组即是一组相同类型组合在一起,使用一个通用的名称,通过分配的下标访问的数据集合中的元素。

数组是具有相同类型的一组数据。当访问数组中的数据时,可以通过下标来指明。c#中数组元素可以为任何数据类型,数组下标从0开始,即第一个元素对应的下标为0,以后逐个递增。数组可以一维也可多维。

一维数组是最基本的数组类型,其声明方法如下:
数据类型 [ ] 数组名 ;
举例:
int [ ] anArray ; // 声明一个整型的一维数组

具有两个维度的数组是二维数组,其声明方法如下:
数据类型 [ , ] 数组名 ;
举例:
int [ , ] anArray ; // 声明一个整型的二维数组
float [ , ]anArrayOfFloats; // 声明一个浮点型的二维数组
string [ , ] anArrayOfStrings; // 声明一个字符串型的二维数组

声明数组变量时,还没有创建数组,还没有为数组中元素分配任何内存空间,因此,声明数组后,需要对数组实例化:
anArray = new int [2,4] ;
anArrayOfStrings = new stirng [2,4] ;

我们也可以用给定的值对数组元素进行初始化。
int [, ] anArray = new int [2, 4] {{1,2,3,4},{5,6,7,8}};
string [, ] anArrayOfStrings = new string [2, 2] {{"某甲","某乙"}, {"冠军" ,"亚军" }};
也可使用下列快捷方式:
int [, ] anArray = {{0,1,2,3},{1,2,3,4}};
string [, ] anArrayOfStrings = {{"某甲","某乙"}, {"冠军" ,"亚军" }};

在C#语言中,数组为我们提供了一些有用的特性,利用这些特性,我们可以完成一些更高级的功能。
数组名.Length :返回一个整数,该整数表示该数组的所有维数中元素的总数。
数组名.Rank :返回一个整数,该整数表示该数组的维数。
数组名.GetLength(int dimension) :返回一个整数,该整数表示该数组的指定维(由参数dimension指定,维度从零开始)中的元素个数。

4.foreach语句针对数组或集合中的每一个元素,循环运行嵌入语句。
foreach语句的语法格式为:
foreach (数据类型 标识符 in 表达式)
嵌入语句


//包含6个元素的一维整数数组; 
int[] mf1=new int[6]; //注意初始化数组的范围,或者指定初值;

//包含6个元素的一维整数数组,初值1,2,3,4,5,6 
int[] mf2=new int[6]{1,2,3,4,5,6};
 
//一维字符串数组,如果提供了初始值设定项,则还可以省略 new 运算符 
string[] mf3={"c","c++","c#"};

//一维对象数组 
Object[] mf4 = new Object[5] { 26, 27, 28, 29, 30 };
 
//二维整数数组,初值mf5[0,0]=1,mf5[0,1]=2,mf5[1,0]=3,mf5[1,1]=4 
int[,] mf5=new int[,]{{1,2},{3,4}};
 
//6*6的二维整型数组 
int[,] mf6=new mf[6,6];

下面来看一个一维字符串数组的遍历 
using System; 
public class MikeCat 

static void PrintArray(string[] arr) 

//打印数组元素,arr.Length 表示数组元素的个数 
for(int i=0;i<arr.Length;i++) 

Console.WriteLine("arr[{0}]={1}",i,arr[i]); 


public static void Main() 

string[] arr={"c","c++","c#"}; 
//将数组作为一个参数传递 
PrintArray(arr); 


程序结果:arr[0]=c arr[1]=c++ arr[2]=c#

下面来看一个4行2列(4*2)的整型数组的遍历: 
using System; 
public class MikeCat 

static void PrintArray(int[,] arr) 

//通过两次FOR循环遍历二维数组 
for(int i=0;i<4;i++)//初始化i作为循环变量,i++实现该变量的自增运算。 
//for循环满足条件后执行完循环体一次后执行i++,然后进入下次循环。简单的c语法,这里做简单介绍供初学者学习。(详细可参阅《c# 高级编程4.0》一书) 

for(int j=0;j<2;j++) 

Console.WriteLine("arr[{0},{1}]={2}",i,j,arr[i,j]);//打印每个二维数组元素 



public static void Main() 

//主函数 
//将数组作为一个参数传递 
PrintArray(new int[,]{{1,2},{3,4},{5,6},{7,8}}; 

}


运行结果:arr[0,0]=1 arr[0,1]=2 arr[1,0]=3 arr[1,1]=4 arr[2,0]=5 arr[2,1]=6 arr[3,0]=7 arr[3,1]=8

 

二.集合

集合(collection)提供了一种结构化组织任意对象的方式,而且我们早就知道集合在日常编程工作中的重要性。.NET类库提供了丰富的集合数据类型,其种类之繁多甚至使许多人看得眼都花了,这些集合对象都具有各自的专用场合。不管怎么说,更多的选择也就意味着更高的灵活性,但同时也意味着更高的复杂性。因此,对集合各个类型的用途和使用条件具有适度的了解是完全必要的。下面就请随我进行一场.NET集合之旅吧!
.NET集合定义

从.NET 的角度看,所谓的集合可以定义为一种对象,这种对象实现一个或者多个System.Collections.ICollection、 System.Collections.IDictionary和System.Collections.IList接口。这一定义把 System.Collections名称空间中的“内置”集合划分成了三种类别:

    *  有序集合:仅仅实现ICollection接口的集合,在通常情况下,其数据项目的插入顺序控制着从集合中取出对象的的顺序。 System.Collections.Stack和 System.Collections.Queue类都是ICollection集合的典型例子。
    *  索引集合:实现Ilist的集合,其内容能经由从零开始的数字检索取出,就象数组一样。System.Collections.ArrayList对象是索引集合的一个例子。
    *  键式集合:实现 IDictionary 接口的集合,其中包含了能被某些类型的键值检索的项目。IDictionary集合的内容通常按键值方式存储,可以用枚举的方式排序检索。 System.Collections.HashTable类实现了IDictionary 接口。

 

https://i.cnblogs.com/EditArticles.aspx?opt=1

 

三.哈希表

 

一,哈希表(Hashtable)简述

在.NET Framework中,Hashtable是System.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); 
从哈希表中移除所有元素: HashtableObject.Clear(); 
判断哈希表是否包含特定键key: HashtableObject.Contains(key); 
下面控制台程序将包含以上所有操作: 
using System; 
using System.Collections; //使用Hashtable时,必须引入这个命名空间 
class hashtable 

public 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=(string)ht["A"]; 
if(ht.Contains("E")) //判断哈希表是否包含特定键,其返回值为true或false 
Console.WriteLine("the E key:exist"); 
ht.Remove("C");//移除一个key/value键值对 
Console.WriteLine(ht["A"]);//此处输出a 
ht.Clear();//移除所有元素 
Console.WriteLine(ht["A"]); //此处将不会有任何输出 

}


三,遍历哈希表

遍历哈希表需要用到DictionaryEntry Object,代码如下: 
for(DictionaryEntry de in ht) //ht为一个Hashtable实例 

Console.WriteLine(de.Key);//de.Key对应于key/value键值对key 
Console.WriteLine(de.Value);//de.Key对应于key/value键值对value 
}

四,对哈希表进行排序

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

Console.Write(skey + ":"); 
Console.WriteLine(ht[skey]);//排序后输出 
}

 

posted @ 2015-09-26 14:54  小唐糖  阅读(606)  评论(0编辑  收藏  举报