前段时间有个任务,就是把参数要按特定顺序排序,就是要是在一张大的参数表中,只选取,2,5,12,9,13,10 这几个参数,并按上述顺序进行排序。

假设这个参数在一个类中。例如: 上述参数序列就存在ParamIndex。

public class ParamDemo
{ public int ParamIndex { get; set; }
public string ParamName{ get; set; }
public string ParamType { get; set; } }

假设有个List

 List<ParamDemo> Params = new List<ParamDemo>();

设置这个排序,需要的是 List<T>.Sort 方法 (IComparer<T>),http://msdn.microsoft.com/zh-cn/library/vstudio/234b841s.aspx

msdn上有一些描述,但是在我手头上的一些c#的书上面都是没有相关的叙述的,还是幸好有同事可以询问,解决了这个问题。

我姑且把这个排序分为三个部分。

1、以 ParamIndex这个值为HashTable的key,构建一个哈希表,来实现上述的顺序,比如说

hash[2] =100

  hash[5] =99

hash[12] =98

hash[9] =97

hash[13] =96

hash[10] =95

表述的不是很清楚,但是更像c里面的指针,一个变量,自身有值,且还能指一个值(貌似更加不清楚了)。其实可以不用HashTable,但是为了预防将来的参数会增多,故选择了HashTable。

具体表述如下:

 int[] numbers = new int[]{,,,,,};
Hashtable hash = new Hashtable();
for (int i = ; i < numbers.Length; i++)
{
hash[numbers[i]] = ( - i); }

随便给我一个参数顺序,都可以加入到HashTable中然后就按这个顺序排序。

2、构建 能够使用List().sort() (IComparer<T>).

这个有不少关键点 ,比较容易的是 这个类必须有IComparer这个接口(我现在不是很清楚什么是接口);上面那一段 数组 哈希表的那一块,必须放在Compare函数里;

这个类必须有Compare函数;这个函数必须要返回 -1 1 0要不就会出错; -1表示小于,1表示大于,0表示等于;其实可以更简单更加简化(后面在补充 2013-07-08),但是觉得容易逻辑上疑惑,所以我更喜欢分开写。

public class ParamComparer : IComparer<ParamDemo>
{ public int Compare(ParamDemo para1, ParamDemo para2)
{
int[] numbers = new int[] { , , , , , };
Hashtable hash = new Hashtable();
for (int i = ; i < numbers.Length; i++)
{
hash[numbers[i]] = ( - i); }
if ((int)hash[para1.ParamIndex] < (int)hash[para2.ParamIndex])
{ return -; }
if ((int)hash[para1.ParamIndex] > (int)hash[para2.ParamIndex])
{ return ; } return ;
} }

能不能把数组声明和 hashtable放在外面但是 这个函数是能用到的。

3、进行排序

  List<ParamDemo> Params = new List<ParamDemo>();
ParamComparer pce = new ParamComparer();
Params.Sort(pce);

好了 先暂时告一段落,没有全部贴出代码的问题就是,可能全部的代码就会出问题。

先这样吧

list<T>中的按特定顺序排序的更多相关文章

  1. SQL Server中使用自定义指定顺序排序

    比如需要对SQL表中的字段NAME进行如下的排序:张三(Z)李四(L)王五(W)赵六(Z) 如果想按 “ 张三.李四.王五.赵六”的顺序排序,则可以使用以下语句: order by charindex ...

  2. 使用mybatis查询数据,按特定顺序排序

    有如下表table_people id          name 1          dwyane 2          james 3          paul 4          bosh ...

  3. C#中List按特定字段排序

    有一个类,如Student,有学号.数学成绩.语文成绩, 存在List列表中,要将List按数学成绩排序,怎么办呢? List<Student> scores=GetScores(); s ...

  4. java中的TreeMap如何顺序按照插入顺序排序

    java中的TreeMap如何顺序按照插入顺序排序 你可以使用LinkedHashMap  这个是可以记住插入顺序的. 用LinkedHashMap吧.它内部有一个链表,保持插入的顺序.迭代的时候,也 ...

  5. 对List中每个对象元素按时间顺序排序

    需求: 需要对List中的每个User按照birthday顺序排序,时间由小到大排列. 代码实现: import java.text.SimpleDateFormat; import java.uti ...

  6. 《剑指Offer》第1题(Java实现):在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

    一.题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该 ...

  7. Java基础面试操作题:读取该文件内容,并按照自然顺序排序后输出到 另一个文件中

    package com.swift; import java.io.FileInputStream; import java.io.FileNotFoundException; import java ...

  8. 【c语言】二维数组中的查找,杨氏矩阵在一个二维数组中,每行都依照从左到右的递增的顺序排序,输入这种一个数组和一个数,推断数组中是否包括这个数

    // 二维数组中的查找,杨氏矩阵在一个二维数组中.每行都依照从左到右的递增的顺序排序. // 每列都依照从上到下递增的顺序排序.请完毕一个函数,输入这种一个数组和一个数.推断数组中是否包括这个数 #i ...

  9. C语言:根据形参c中指定的英文字母,按顺序打印出若干后继相邻字母,-主函数中放入一个带头节点的链表结构中,h指向链表的头节点。fun函数找出学生的最高分-使用插入排序法对字符串中的字符进行升序排序。-从文件中找到指定学号的学生数据,读入次学生数据,

    //根据形参c中指定的英文字母,按顺序打印出若干后继相邻字母,输出字母的大小与形参c一致,数量由形参d指定.例如:输入c为Y,d为4,则输出ZABC. #include <stdio.h> ...

随机推荐

  1. 廖雪峰Java1-3流程控制-5循环

    while循环 while循环首先判断条件: 条件满足时循环:条件不满足时退出循环 如果一开始条件就不满足,一次都不循环.如while false int sum = 0; int n = 1; wh ...

  2. go语言学习--指针数组和数组指针

    数组指针(也称行指针)定义 int (*p)[n];()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长.也就是说执行p+1时,p要跨过n个整型数据的 ...

  3. BBC曝光:每天10000步,竟是商家的营销骗局

    原文: https://new.qq.com/cmsn/20190112A14JRD00 导语:日本人平均每天行走3500-5000步,于是计步器公司就想,既然这么个数值大部分人都能达到,如果把平均值 ...

  4. IDEA远程调试

    问题:         通常在java打成可运行的Jar项目时,运行jar时调试很不方便,特别是要在linux上面执行jar包的情况.此时需要将这个项目打成Jar包(如果是maven项目,直接使用pa ...

  5. CRM 2016 IFrame_A嵌入 EXT.net 页面 a.aspx,刷新另一IFrame_B嵌入 b.aspx gird.

    说白了就是一个IFrame页面,执行另一IFrame页面的函数.  a.aspx JS: parent.Xrm.Page.getControl("IFRAME_B").getObj ...

  6. CRM 更新解决方案之注意事项

    一般需要开发新功能时,企业或者软件公司往往会先从生产环境克隆出一台测试用系统. 开发人员会在测试系统中对功能进行开发或者测试. 这时当新功能开发和测试完成之后,需要将新的解决方案导入生产环境. 导入时 ...

  7. 在javascript中toString 和valueOf的区别

    1.toString()方法:主要用于Array.Boolean.Date.Error.Function.Number等对象转化为字符串形式.日期类的toString()方法返回一个可读的日期和字符串 ...

  8. web框架原理

    web框架的原理: 所有的web应用其实本质上就是socket服务端,而我们的浏览器就是socket客户端. 那么知道了这个之后我们就可以基于socket来写一个我们的服务端: import sock ...

  9. MySQL通过游标来实现通过查询结果集循环

    /*我们有时候会遇到需要对 从A表查询的结果集S_S 的记录 进行遍历并做一些操作(如插入),且这些操作需要的数据或许部分来自S_S集合*/ /*临时存储过程,没办法,不能直接在查询窗口做这些事.*/ ...

  10. 2013年第四届蓝桥杯JavaB组省赛试题解析

    题目及解析如下: 题目大致介绍: 第一题到第四题是结果填空,方法不限只要得到最后结果就行 第五题和第六题是代码填空题,主要考察算法基本功和编程基本功 第七题到第十题是编程题,要求编程解决问题 第一题 ...