题目:
学生类包括成绩、科目和学号,请根据课程成绩grade将学生进行排序。
功能说明:
1.Student类继承IComparable接口,实现CompareTo()方法
IComparable:定义由值类型或类实现的通用比较方法,创建特定于类型的比较方法以对实例进行排序。
2.自行实现的CompareTo()方法会在Array.Sort()内部进行元素两两比较,最终实现排序。
接口提供的方法返回值是int类型的,负数代表小于,0代表等于,正数代表大于。所以对数字之外的 自定义比较器,需要人工设定什么是“大”,什么是“小”
设计流程:
1.针对对象本身。为了使对象自己能够执行比较操作,该对象必须实现IComparable接口,即至少具有一个CompareTo()成员。
int Comparable CompareTo(object obj)
它根据当前对象与要比较的对象的“大小”返回一个正数、0或一个负数。
2.随后遍历Student里的实例排序后输出即可。
关键源码展示:
1.创建实现IComparable接口
public class Student : IComparable
{
public double mygrade;
public string mysubject, myID;
public Student() { }
public Student(double grade, string subject, string id)
{
mygrade = grade;
mysubject = subject;
myID = id;
}
//添加关键代码如下
int IComparable.CompareTo(Object obj)
{
if (obj is Student)
{
Student castObj= (Student)obj;
if (this.mygrade < castObj.mygrade) return 1;
else if(this.mygrade>castObj.mygrade) return -1;
else return 0;
}
throw new ArgumentException("object is not a Student");
}
}
2.主函数
internal class Program
{
private static void Main(string[] args)
{
Student[] students = new Student[5];
students[0] = new Student(50.0, "windows程序设计", "001");
students[1] = new Student(90.0, "windows程序设计", "002");
students[2] = new Student(100.0, "windows程序设计", "003");
students[3] = new Student(70.0, "windows程序设计", "004");
students[4] = new Student(80.0, "windows程序设计", "005");
//添加关键代码如下
Array.Sort(students);//默认只对基本类型排序
foreach (Student s in students)
{
Console.WriteLine(s.mygrade+" "+s.mysubject+" "+s.myID);
}
}
}
运行结果截图:
总结:
本次c#实验也是收获满满呐~通过默认排序方法,我们不用重写任何Sort()方法的实现代码,就能对单参数类型的List数据进行单一规则的排序,如果通过对这些方法进行改进就可以轻松做到对多参数、多规则的复杂排序。关于系统默认的方法,单一参数时会默认进行升序排序。但遇到多参数 例如本题(grade、id)排序时,我们需要对该默认方法进行修改。同时对于接口和foreach的印象再次加深,实战永远是积累经验的最佳方式。