C#编程(五十二)----------有序列表

有序列表

如果需要基于对所有集合排序,就可以使用SortedList<TKey,TValue>类.这个类按照键给元素排序.这个集合中的值和键都可以使用任意类型.

下面的例子创建了一个有序列表,其中键和值类型都是string.默认的构造函数创建了一个空列表,再用Add()方法添加书.使用重载的构造函数.可以定义列表的容量,传递实现了IComparer<TKey>接口的对象,该接口用于给列表中的元素排序.

使用Add(Tkey,Tvalue)方法,第一个参数是键,第二个参数是值.除了使用Add()方法之外,还可以使用索引器添加元素到列表中.索引器需要把键作为索引参数.如果键已存在,Add()方法就抛出一个ArgumentException类型的异常.如果所引起使用相同的键,就用新值代替旧值.

SortedList<TKey,TValue>类只允许每个键有一个对应的值,如果需要每个键对应多个之,可以使用Lookup<TKey,TELement>类.

案例:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

namespace 有序列表

{

class Program

{

static void Main(string[] args)

{

//如果要用排好顺序的表,可以使用SortedList<TKey,TValue>来给元素排序

SortedList<string, string> books = new SortedList<string, string>();

books.Add("tangseng", "001");

books.Add("sunwukong", "002");

books.Add("zhubajie", "003");

books.Add("shaheshang", "004");

//键是不允许重复,下面我们用Add方法重新添加一次tangseng

//books.Add("tangseng","hahah");抛出异常

//但是如果使用索引来赋值,如果键存在,则覆盖,不存在,相当于使用Add方法

books["tangseng"] = "hahaha";

foreach (var item in books.Keys)

{

Console.WriteLine(item);

}

foreach (var item in books.Values)

{

Console.WriteLine(item);

}

//一次性遍历键值

foreach (KeyValuePair<string, string> item in books)

{

Console.WriteLine("名字: {0} , 序号 : {1}", item.Key, item.Value);

}

/*

* 分析结果可知,tangseng被替换成了hahaha

*

* 下面简单介绍一下SortedList<TKey,TValue>中的方法与属性

* Capacity 这个属性用来设置与得到有序列表的容量,与IList一样,也时成倍增长的

* Comparer 返回与有序列表相关的比较器,可以从构造函数中传入该比较器

* Remove() RemoveAt() 按键删除与按索引删除

* ContainsKey();ContainsValue;检查是不是有包含指定值的键,或者值

* TryGetValue() 尝试获得指定键的值,如果有就是true,并用out把值带回来,没有就是false

*/

//按键删除

Console.WriteLine("按键删除");

books.Remove("tangseng");

foreach (KeyValuePair<string, string> item in books)

{

Console.WriteLine("名字 : {0}, 序号 : {1}", item.Key, item.Value);

}

//可以看出tangseng被删除了

//下面我们按索引删除

books.RemoveAt(0);

Console.WriteLine("按索引删除");

foreach (KeyValuePair<string, string> item in books)

{

Console.WriteLine("名字 : {0}, 序号 : {1}", item.Key, item.Value);

}

//结果中看出shaheshang被删除,证明删除索引是以排序后的顺序为准,不是以插入的顺序为准

//检查是否包含tangseng,检查是否包含zhubajie(键)

Console.WriteLine("检查是否包含tangseng: {0}", books.ContainsKey("tangseng"));

Console.WriteLine("检查是否包含zhubajie: {0}", books.ContainsKey("zhubajie"));

//检查是否包含001,检查是否包含002(值)

Console.WriteLine("是否包含001: {0}", books.ContainsValue("001"));

Console.WriteLine("是否包含002: {0}", books.ContainsValue("002"));

//此处的索引值是按排序后的顺序

int keyIndex = books.IndexOfKey("zhubajie");

Console.WriteLine("zhubajie的索引值: {0}", keyIndex);

string value = "";

if (books.TryGetValue("tangseng",out value))

{

Console.WriteLine("得到了tangseng的值 : {0}",value);

}

string value2 = "";

if (books.TryGetValue("zhubajie", out value2))

{

Console.WriteLine("得到了zhubajie的值 : {0}", value2);

}

Console.ReadKey();

}

}

}

分析:使用Values和Keys属性访问值和键.如果尝试使用索引器访问一个元素,但所传递的键不存在,就会抛出异常.为了避免一场,可以使用ContainsKey()方法,如果所传递的键存在于集合中,这个方法返回true,也可以调用TryGetValue()方法,该方法尝试获得指定键的值.如果指定键对应的值不存在,该方法就会抛出异常.

时间: 2024-07-29 04:17:53

C#编程(五十二)----------有序列表的相关文章

QT开发(五十二)———QML语言

QT开发(五十二)---QML语言 QML是一种声明语言,用于描述程序界面.QML将用户界面分解成一块块小的元素,每一元素都由很多组件构成.QML定义了用户界面元素的外观和行为:更复杂的逻辑则可以结合JavaScript脚本实现. 一.QML基础语法 1.Import语句 QML代码中,import语句一般写在头几行,主要用途如下:     A.包含类型的全名空间     B.包含QML代码文件的目录     C.JavaScript代码文件 格式如下: import Namespace Ver

shell编程(十二)--- 添加用户示例

[[email protected] Learn]# cat useradd-final.sh  #!/bin/bash # DEBUG=0 ADD=0 DEL=0 help() { echo "Usage: $(basename $0) -v | --verbose | --add user1,user2,... | --del user1,user2,... | -h | --help" } while [ $# -ne 0 ] do case $1 in -h | --help 

Linux系统裁剪之二(Bash脚本编程之十二)

Linux系统裁剪之二(Bash脚本编程之十二) 系统函数库 ·Linux系统的启动流程     1,POST(加电自检) 计算机本身并不会执行程序,它只是一堆破铜烂铁,但是它可以在开机的时候先去载入一段程序,系统在刚刚启动的时候能够实现将某个ROM芯片中的程序映射到CPU能够寻址的地址空间中去,并且让CPU能够执行其中的指令,这些指令大部分都是用来做系统检测的,当检测完成后,如果系统中所有的基本硬件和核心硬件都没有问题的话,接下来就会根据BIOS中设定的系统启动次序(Boot Sequence

Windows界面编程第十二篇 位图显示特效 飞入效果与伸展效果

分享一下我老师大神的人工智能教程吧.零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!http://www.captainbed.net 转载请标明出处,原文地址:http://blog.csdn.net/morewindows/article/details/8696726 欢迎关注微博:http://weibo.com/MoreWindows Windows界面编程之位图显示特效系列目录: 1. <Windows界面编程第九篇位图显示特效交错效果> http:/

第五十二个知识点:选择一个先进的应用概念,如电子投票,拍卖或多方计算。这样一个系统的大致安全需求是什么

第五十二个知识点:选择一个先进的应用概念,如电子投票,拍卖或多方计算.这样一个系统的大致安全需求是什么 这是我们认为每个密码学博士一年级都应该知道的52件事中的最后一件.你可能已经收集了过去的52个博客,我们希望学生知道从理论到实践的各个方面.但关键是你需要在密码学中考虑的不仅是对遵守规则的玩家的安全,还有对不遵守规则的玩家的安全.让我们从投票.拍卖和多方计算的角度来研究这个问题. 让我们先讨论一下三个应用程序的含义. 在投票中,我们根绝投票者进行一些投票方案(得票最多者当选.多选.赞成投票或其

对于未来编程的十二种预测

凝视水晶球,我们试图寻找未来五年中关于编程会发生什么,哪些会激动人心. 技术领域快速变革着,而用于构建这些技术的工具也随之不断发展.如果你不能超越当前的项目,那你就只能在兔子洞里越陷越深了. 为了帮助您呈现一个精彩的未来,我们预测了未来五年内编程领域将进行的颠覆性变革.由于我们的水晶球的主观色彩很浓,以下这些猜想也许并不是普遍适用的,还有一些或许在五年内不能完全实现.有些虽然已成为了现实,但真理的确立不是一蹴而就的. 亲爱的读者,请你快速阅读吧,因为未来将以超越我们认知的速度发展着. 1. GP

C#高级编程五十五天----HashSet和SortedSet

集 饱含不重复元素的集合称为"集(set)". .NET4包含两个集(HashSet<T>和SortedSet<T>),他们都实现ISet<T>接口.HashSet<T>即包含不重复元素的无序列表,SortedSet<T>集包含不重复元素的有序列表. ISet<T>接口提供的方法可以创建合集,交集,或者给出一个集合时另一个集的超集或子集的信息. 案例: //使用HashSet:重复的元素自动被移除,但是不排序 va

C#高级编程五十四天----Lookup类和有序字典

Lookup类 Dictionary<Tkey,TValue>只为每个键支持一个值.新类Lookup<Tkey,TValue>是.NET3.5中新增的,它类似与Dictionary<Tkey,TElement>,但把键映射带一个值集上.这个类在程序及System.Core中实现,用System,Linq命名空间定义. Lookup<Tkey,TElement>的方法和属性如下表: 属性名或者方法名 说明 Count 属性Count返回集合中的元素个数 Ite

ActionScript3游戏中的图像编程(连载五十二)

总目录:http://blog.csdn.net/iloveas2014/article/details/38304477 3.2.3 反向斜角实现凹陷的浮雕效果 Photoshop的斜角滤镜通过方向参数来进行设置,在Flash里面也不难,只要把高亮显示和阴影的颜色交换一下,或者将角度,距离的其中一项设置成负数即可达到效果.(图 3.46~图 3.48)(注意,这里我加了个投影滤镜来打底) 图 3.46 通过交换加亮和阴影的颜色来达到凹陷的效果 图 3.47 通过将距离设置为负数来达到凹陷的效果