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

C#数组排序的两种常用方法

公冶元青
2023-03-14
本文向大家介绍C#数组排序的两种常用方法,包括了C#数组排序的两种常用方法的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了C#数组排序的两种常用方法。分享给大家供大家参考。具体如下:

1.第一个例子

定义代码

#region Array数组排序1
public class Pigeon : IComparable<Pigeon>
//类元素本身继承比较接口
{
int XValue;
int YValue;
public string BatchNo { get; set; }
public int CompareTo(Pigeon other)
{
  if (other == null)
 throw new ArgumentNullException("比较参数为空");
  //按第三个字符比较
  XValue = Convert.ToInt32(this.BatchNo.Substring(2, 1));
  YValue = Convert.ToInt32(other.BatchNo.Substring(2, 1));
  if (XValue == YValue)
  {
 return 0;
  }
  else if (XValue < YValue)
  {
 return -1;   //返回-1,X排在Y的前面
  }
  else
  {
 return 1;    //返回1,X排在Y的后面
  }
}
}
#endregion

测试代码

#region 测试Array数组排序1
private void button3_Click(object sender, EventArgs e)
{
  Pigeon[] pigeons = new Pigeon[]{
 new Pigeon(){BatchNo="1256"},
 new Pigeon(){BatchNo="1236"},
 new Pigeon(){BatchNo="1276"},
 new Pigeon(){BatchNo="1216"}
  };
  Array.Sort(pigeons);
  string ResultMsg = "";
  foreach (Pigeon o in pigeons)
  {
 ResultMsg += o.BatchNo + "\r\n";
  }
  MessageBox.Show(ResultMsg);
}
#endregion

1.第二个例子

定义代码

#region Array数组排序
public class MyBatch   //数组元素类
{
public string BatchNo { get; set; }
}
public enum CompareType   //比较类型枚举
{
ThreeChar =0,
FourChar=1
}
public class MyBatchCompare:IComparer<MyBatch>
//定义了一个比较类
{
private CompareType compareType;//定义排序类型
public MyBatchCompare(CompareType compareType)
{
  //构造函数中初始化比较类型
  this.compareType = compareType;
}
public int Compare(MyBatch x, MyBatch y)
{
  int XValue;
  int YValue;
  if (x == null) throw new ArgumentNullException("x值为空");
  if (y == null) throw new ArgumentNullException("y值为空");
  switch (compareType)
  {          
 case CompareType.ThreeChar:
   //按第三个字符比较从小到大排序
   XValue = Convert.ToInt32(x.BatchNo.Substring(2,1));
   YValue = Convert.ToInt32(y.BatchNo.Substring(2,1));
   if (XValue == YValue)
   {
 return 0;
   }
   else if (XValue < YValue)
   {
 return -1;   //返回-1,X排在Y的前面
   }
   else
   {
 return 1;    //返回1,X排在Y的后面
   }
 case CompareType.FourChar:
   //按第四个字符比较从小到大排序
   XValue = Convert.ToInt32(x.BatchNo.Substring(3,1));
   YValue = Convert.ToInt32(y.BatchNo.Substring(3,1));
   if (XValue == YValue)
   {
 return 0;
   }
   else if (XValue < YValue)
   {
 return -1;   //返回-1,X排在Y的前面
   }
   else
   {
 return 1;    //返回1,X排在Y的后面
   }
 default:
   throw new ArgumentException("比较类型参数错误");
  }
}
}
#endregion

测试代码

#region Array数组排序
private void button2_Click(object sender, EventArgs e)
{
  MyBatch[] batchs ={
   new MyBatch(){BatchNo="1234"},
   new MyBatch(){BatchNo="1263"},
   new MyBatch(){BatchNo="1218"},
   new MyBatch(){BatchNo="1242"}
    };
  //按第三个字符从小到大排
  Array.Sort(batchs,new MyBatchCompare(CompareType.ThreeChar));
  string ResultMsg = "";
  foreach (MyBatch o in batchs)
  {
 ResultMsg += o.BatchNo + "\r\n";
  }
  MessageBox.Show(ResultMsg);
  //按第四个字符从小到大排序
  Array.Sort(batchs, new MyBatchCompare(CompareType.FourChar));
  ResultMsg = "";
  foreach (MyBatch o in batchs)
  {
 ResultMsg += o.BatchNo + "\r\n";
  }
  MessageBox.Show(ResultMsg);
}
#endregion

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

 类似资料:
  • 本文向大家介绍JavaScript数组排序的六种常见算法总结,包括了JavaScript数组排序的六种常见算法总结的使用技巧和注意事项,需要的朋友参考一下 前言 着急用的话,选择前两个就行了,后面的看看就好。 开发中,遇到数组排序的需求很频繁,这篇文章会介绍几个常见排序思路。 一、希尔排序(性能最好) 如果要从大到小排列,则 while(arr[n] > arr[n - interval] &&

  • 本文向大家介绍JavaScript中三种常见的排序方法,包括了JavaScript中三种常见的排序方法的使用技巧和注意事项,需要的朋友参考一下 1、快速排序: 2、插入排序 3、冒泡排序 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持呐喊教程!

  • 本文向大家介绍C#使用linq对数组进行筛选排序的方法,包括了C#使用linq对数组进行筛选排序的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#使用linq对数组进行筛选排序的方法。分享给大家供大家参考。具体如下: 希望本文所述对大家的C#程序设计有所帮助。

  • 本文向大家介绍Java HashMap两种简便排序方法解析,包括了Java HashMap两种简便排序方法解析的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了Java HashMap两种简便排序方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 HashMap的储存是没有顺序的,而是按照key的HashCode实现. key=手机

  • 本文向大家介绍用Java集合中的Collections.sort方法如何对list排序(两种方法),包括了用Java集合中的Collections.sort方法如何对list排序(两种方法)的使用技巧和注意事项,需要的朋友参考一下 第一种是list中的对象实现Comparable接口,如下: 测试一下: 输出结果如下 a b 第二种方法是根据Collections.sort重载方法来实现,例如:

  • 本文向大家介绍Objective-C语言排序数组,包括了Objective-C语言排序数组的使用技巧和注意事项,需要的朋友参考一下 示例