集合>哈希表类Hashtable

Hashtable一种键值对的集合 ,哈希表内部的排列是无序的,而且哈希表没有提供排序方法。

集合>哈希表类Hashtable>构造普通哈希表

代码using System;using System.Collections.Generic;using System.Text;using System.Collections;namespace ConsoleApplication1{    class Program    {        static void Main(string[] args)        {            //使用所有默认值构建哈希表实例            Hashtable ht = new Hashtable();            //指定哈希表实例的初始容量为20个元素            Hashtable ht1 = new Hashtable(20);            //指定初始容量为20个元素,加载因子为0.8的哈希表实例,加载因子大,哈希表自动扩展容量也大。            Hashtable ht2 = new Hashtable(20, 0.8f);            //实例化一个SortedList。            SortedList sl = new SortedList();            sl.Add("键一", "键值一");            sl.Add("键二", "键值二");            sl.Add("键三", "键值三");            //传入实现了IDictionary接口的参数创建哈希表。            Hashtable ht3 = new Hashtable(sl);        }    }}

集合>哈希表类Hashtable>获取哈希表值

代码using System;using System.Collections.Generic;using System.Text;using System.Collections;namespace useHashtable{    class Program    {        static void Main(string[] args)        {            //初始化哈希表            Hashtable hl = new Hashtable();            //使用Add方法向哈希表添加元素。            hl.Add("键一", "键值一");            hl.Add("键二", "键值二");            hl.Add("键三", "键值三");            hl.Add("键四", "键值四");            hl.Add("键五", "键值五");            hl.Add("键六", "键值六");            hl.Add("键七", "键值七");            DisplayResult(hl);            Console.WriteLine("通过键获取键值:"+ hl["键一"]);            Console.WriteLine("移除哈希表中的元素");            hl.Remove("键二");            Console.WriteLine("哈希表中的元数总数是:" + hl.Count);            DisplayResult(hl);            Console.ReadLine();        }        static void DisplayResult(Hashtable tl)        {            foreach (DictionaryEntry de in tl)            {                 Console.WriteLine("哈希表中的键:{0},对应的值{1}",de.Key,de.Value);            }        }    }}

集合>哈希表类Hashtable>哈希表排序

代码using System;using System.Collections.Generic;using System.Text;using System.Collections;namespace HashSort{    class Program    {        static void Main(string[] args)        {            Hashtable ht = new Hashtable();            ht.Add("key1", "this is value1");            ht.Add("key3", "this is vlaue3");            ht.Add("key2", "this is value2");            ht.Add("key4", "this is value4");            Console.WriteLine("排序前的哈希键值顺序为:");            foreach (DictionaryEntry de in ht)            {                 Console.WriteLine("键{0},值{1}", de.Key, de.Value);            }            ICollection keys = ht.Keys;            ArrayList al = new ArrayList(keys);            al.Sort();            Console.WriteLine("排序后的哈希键值顺序为:");            foreach (object key in al)            {                Console.WriteLine("键{0},值{1}", key, ht[key]);            }            Console.ReadLine();        }    }}

集合>哈希表类Hashtable>哈希表搜索

代码using System;using System.Collections.Generic;using System.Text;using System.Collections;namespace HashtableSearch{    class Program    {        static void Main(string[] args)        {            Hashtable ht = new Hashtable();            ht.Add("key1", "this is value1");            ht.Add("key3", "this is vlaue3");            ht.Add("key2", "this is value2");            ht.Add("key4", "this is value4");                      ICollection keys = ht.Keys;            ArrayList al = new ArrayList(keys);            al.Sort();            //在这里使用ArrayList的BinarySearch搜索指定键值的值。            int searchResult = al.BinarySearch("key3");            if (searchResult > 0)            {                Console.WriteLine("搜索到的结果为:键{0},值{1}",al[searchResult],ht[al[searchResult]]);            }            else            {                Console.WriteLine("没有搜索到有效的结果值");            }            Console.ReadLine();        }    }}

集合>SortedList排序列表类

SortedList对象是可以排序的字典对象。与哈希表不同的是,SortedList内部的键是一个数组,值也是一个数组。这两个数组有初始容量,可自动扩充,SortedList根据键来排序,所键要实现IComparable接口。

集合>SortedList排序列表类>创建和操作

代码using System;using System.Collections.Generic;using System.Text;using System.Collections;namespace ConsoleApplication1{    class Program    {        static void Main(string[] args)        {            //默认值构建            SortedList sl=new SortedList();            sl.Add("键1", "键值一");            sl.Add("键2", "键值二");            sl.Add("键3", "键值三");            sl.Add("键4", "键值四");            sl.Add("键5", "键值六");            sl.Add("键6", "键值七");            Console.WriteLine("排序字典的最初的初始化列表为:");            DisplayResult(sl);            sl.Remove("键5");            Console.WriteLine("键6的键值是:{0}", sl["键6"]);                        Console.ReadLine();        }        static void DisplayResult(SortedList sl)        {            foreach (DictionaryEntry de in sl)            {                Console.WriteLine("键:{0},键值为:{1}", de.Key, de.Value);            }        }    }}

集合>哈希表类Hashtable和SortedList排序列表类的更多相关文章

  1. 11、C#基础整理(特殊集合和哈希表)

    特殊集合:队列.栈 一.栈Stack类:先进后出,没有索引 Stack ss = new Stack(); 1.增加数据:push :将元素推入集合 ss.Push(); ss.Push(); ss. ...

  2. C# 哈希表(Hashtable)用法笔记

    一.什么是Hashtable? Hashtable 类代表了一系列基于键的哈希代码组织起来的键/值对.它使用键来访问集合中的元素. 当您使用键访问元素时,则使用哈希表,而且您可以识别一个有用的键值.哈 ...

  3. C#部分---特殊集合:stack栈集合、queue队列集合、哈希表集合。

    1.stack栈集合:又名 干草堆集合 栈集合 特点:(1)一个一个赋值 一个一个取值(2)先进后出实例化 初始化 Stack st = new Stack(); //添加元素用push st.Pus ...

  4. 数据结构是哈希表(hashTable)

    哈希表也称为散列表,是根据关键字值(key value)而直接进行访问的数据结构.也就是说,它通过把关键字值映射到一个位置来访问记录,以加快查找的速度.这个映射函数称为哈希函数(也称为散列函数),映射 ...

  5. Java List集合和哈希表

    List集合和Set集合,先来看List集合. List集合存储元素的特点: 1.有序(List集合中的元素有下标):存进去是什么样,取出来还是什么样 2.可重复 可以结合以下的简单代码来看一看. i ...

  6. java数据结构——哈希表(HashTable)

    哈希表提供了快速的插入操作和查找操作,每一个元素是一个key-value对,其基于数组来实现. 一.Java中HashMap与Hashtable的区别: HashMap可以接受null键值和值,而Ha ...

  7. js实现哈希表(HashTable)

    在算法中,尤其是有关数组的算法中,哈希表的使用可以很好的解决问题,所以这篇文章会记录一些有关js实现哈希表并给出解决实际问题的例子. 第一部分:相关知识点 属性的枚举: var person = { ...

  8. Python 字典和集合基于哈希表实现

    哈希表作为基础数据结构我不多说,有兴趣的可以百度,或者等我出一篇博客来细谈哈希表.我这里就简单讲讲:哈希表不过就是一个定长数组,元素找位置,遇到哈希冲突则利用 hash 算法解决找另一个位置,如果数组 ...

  9. 第三十四篇 玩转数据结构——哈希表(HashTable)

    1.. 整型哈希函数的设计 小范围正整数直接使用 小范围负整数整体进行偏移 大整数,通常做法是"模一个素数"   2.. 浮点型哈希函数的设计 转成整型进行处理   3.. 字符串 ...

随机推荐

  1. springboot scheduled并发配置

    本文介绍如何使用springboot的sheduled实现任务的定时调度,并将调度的任务实现为并发的方式. 1.定时调度配置scheduled 1)注册定时任务 package com.xiaoju. ...

  2. css系列教程1-选择器全解

    全栈工程师开发手册 (作者:栾鹏) 一个demo学会css css系列教程1-选择器全解 css系列教程2-样式操作全解 css选择器全解: css选择器包括:基本选择器.属性选择器.伪类选择器.伪元 ...

  3. [置顶] 一个demo学会c#

    学习了c#4.5高级编程这本书,自己喜欢边学边总结边写demo,所以写了这篇文章,包含了大部分的c#编程知识.让你一个demo掌握c#编程,如果有问题可以留言. 此demo主要包括五个文件:Stude ...

  4. TCP/IP四层模型与OSI参考模型

    TCP/IP四层模型: 1.链路层(数据链路层/网络接口层):包括操作系统中的设备驱动程序.计算机中对应的网络接口卡 2.网络层(互联网层):处理分组在网络中的活动,比如分组的选路. 3.运输层:主要 ...

  5. linux_base_commond_one

    1.cd commond a. cd usr 切换到该目录下usr目录  b. cd ../ 切换到上一层目录  c.cd / 切换到系统根目录  d. cd ~ 切换到用户主目录 e. cd - 切 ...

  6. 用Python来实现列举某个文件夹内所有的文件列表

    用Python来实现列举某个文件夹内所有的文件列表.吾八哥我动手写代码之前分析了下,遍历一个文件夹,肯定是需要用到os模块了,查阅模块帮助信息,可知os.listdir()方法可以列举某个文件夹内的所 ...

  7. memcached+狀態模式+工廠方法使用

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  8. btsync 分享资源

    Btsync是一款跨平台软件,可以在不同的设备之间共享文件. Btsync类似于BT下载,用户对用户(多用户)之间的传送. 文档的分享者可以将资源放到文件夹下,生成共享Key,分享给接受者,接受者只需 ...

  9. mongdb单节点安装方法

    mongo单节点环境安装(linux) 安装包 下载地址: (https://www.mongodb.com/download-center) 用户权限/目录 创建 dbuser用户 groupadd ...

  10. bootstrap学习之利用CSS属性pointer-events禁用表单控件

    参考链接: CSS3 pointer-events:none应用举例及扩展 首先pointer-events在除去SVG中的应用只有两个值:AUTO | NONE pointer-events:non ...