当前位置: 首页 > 编程笔记 >

C#使用IComparer自定义List类实现排序的方法

洪景铄
2023-03-14
本文向大家介绍C#使用IComparer自定义List类实现排序的方法,包括了C#使用IComparer自定义List类实现排序的方法的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了C#使用IComparer自定义List类实现排序的方法。分享给大家供大家参考。具体如下:

List类中不带参数的Sort函数可以用来为List类中的元素排序,但如果List类中的元素类型本身不能直接进行比较(如自定义的struct和很多class),或是希望采用更加灵活的自定义比较方式,可以通过继承了IComparer接口的函数来解决。

代码示例如下:

1)声明一个类

/// <summary>
/// 人物类
/// </summary>
public class Person
{
  public string Name;
  public int Age;
  public override string ToString()
  {
    return "Name: " + Name + " Age: " + Age;
  }
}

2)声明一个继承了接口IComparer的类

/// <summary>
/// 比较人物类实例大小,实现接口IComparer
/// </summary>
public class PersonComparer : IComparer<Person>
{
  public int Compare(Person x, Person y)
  {
    if (x == null && y == null) return 0;
    if (x == null) return -1;
    if (y == null) return 1;
    //TODO:Person类实例X与Y的比较规则
    //按姓名由小到大排列,姓名相同的人年龄大的在前
    {
      int temp = string.Compare(x.Name, y.Name);
      if (temp > 0) return -1;
      else if (temp < 0) return 1;
      if (x.Age > y.Age) return 1;
      if (x.Age < y.Age) return -1;
    }
    return 0;
  }
}

3)Main函数,建立一个List,并使用刚建立的PersonComparer类中的规则对List进行排序

static void Main(string[] args)
{
  List<Person> a = new List<Person>();
  a.Add(new Person() { Name = "Tsybius", Age = 23 });
  a.Add(new Person() { Name = "Galatea", Age = 21 });
  a.Add(new Person() { Name = "Lucius", Age = 22 });
  a.Add(new Person() { Name = "Septimus", Age = 22 });
  a.Add(new Person() { Name = "Octavius", Age = 22 });
  a.Add(new Person() { Name = "Lucius", Age = 24 });
  //输出a中全部元素
  Console.WriteLine("排序前");
  foreach (var v in a)
  {
    Console.WriteLine(v.ToString());
  }
  Console.WriteLine("-");
  //对a进行排序
  a.Sort(new PersonComparer());
  //输出a中全部元素
  Console.WriteLine("排序后");
  foreach (var v in a)
  {
    Console.WriteLine(v.ToString());
  }
  Console.WriteLine("-");
  Console.ReadLine();
}

4)程序运行示例

希望本文所述对大家的C#程序设计有所帮助。

 类似资料:
  • 本文向大家介绍Python自定义sorted排序实现方法详解,包括了Python自定义sorted排序实现方法详解的使用技巧和注意事项,需要的朋友参考一下 题目 输入一个正整数数组,把数组里面的所有属猪拼接起来成为一个数打印能拼接起来的所有数字中最大/最小的那个。 思考 直观想法就是求出这个数组中所有数字的全排列,然后拼接起来,再比较大小即可,当然复杂度过高。 另一个想法,我们可以定义一个排序规则

  • 问题内容: 我有以下数据框,我想先按“重要性”排序,然后再按“名称”排序: 我一直在努力做到这一点使用中提供了答案这个职位,但我不能得到它的工作。 最终结果应该是这样的 问题答案: 一种方法是使用自定义字典创建“等级”列,然后使用进行排序,然后在排序后删除该列:

  • 本文向大家介绍C#自定义签名章实现方法,包括了C#自定义签名章实现方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#自定义签名章实现方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的C#程序设计有所帮助。

  • 本文向大家介绍C#编程实现自定义热键的方法,包括了C#编程实现自定义热键的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#编程实现自定义热键的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的C#程序设计有所帮助。

  • 本文向大家介绍C#使用List类实现动态变长数组的方法,包括了C#使用List类实现动态变长数组的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#使用List类实现动态变长数组的方法。分享给大家供大家参考。具体如下: C#中的list可以当做数组使用,而且无需定义长度,完全是动态的 希望本文所述对大家的C#程序设计有所帮助。

  • 你的类型需要排序关系用于定义集合的排序和搜索。 .NET 框架定义两个接口描述类型的排序关系: IComparable<T> 和 IComparer<T> 。IComparable 定义了类型的自然排序。类型实现的 IComparer 描述的另一个排序。你可以在接口中提供具体类型的比较并避免运行时低效率的自定义关系操作符( < ,>,<=,>= )的实现。本原则会讨论怎么实现排序关系,.NET 核