2016新编C 哈希表-遍历-排序.docVIP

  1. 1、本文档共28页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
2016新编C 哈希表-遍历-排序.doc

一、哈希表(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]);//排序后输出 帮助,google等一搜索多的是 空之殇 等级: 2楼 得分:0 Mark 骗子不可怕,就怕骗子有文化! 等级: 3楼 得分:5 用得不多,不过如果是需要用到排序的地方,建议不要使用hashtable,因为hashtable在序列化与反序列化时会重新排序,把原本的顺序打乱 等级: 4楼 得分:5 怎么不用Dictionary 别腰刀的猪猪 等级: 5楼 得分:5 Dictionary结构和hashtable差不多,都是键值对,但效率高一些 三尾 拿起砖头上路. 等级: 执手相看泪眼,竟无语凝噎 等级: 7楼 得分:5 for(DictionaryEntry de in ht) for(string skey in akeys) 都应该是foreach吧. 可可西里 呼叫中心开发 系统集成 客户服务(CRM)软件开发 门户网站开发 等级: 8楼 得分:0 hashtable他是不排序的 综艺一哥 等级: 9楼 得分:0 看我blog的最新一篇 等级: 10楼 得分:0 呵呵我们考试准备要用这个演讲~所以我来请教一下各位高手,望不吝赐教! 嘎嘎 等级: 11楼 得分:0 能不能帮忙总结下啊 百度上的太散了~弄个完整版的欧周一好用~谢谢各位帮帮忙啊~ 等级: 12楼 得分:0 自己顶 东北小胖 等级: 13楼 得分:0 HTML code html head

您可能关注的文档

文档评论(0)

czy2014 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档