题目说明:学生类包括成绩、科目和学号,请根据课程成绩grade将学生进行排序。
设计思路:
重写对类的排序函数以实现和其他标准类型一样的排序
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)
{
Student stu = (Student)obj;
if (this.mygrade > stu.mygrade) return 1;
else if (this.mygrade < stu.mygrade) return -1;
else return 0;
}
}
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("grade:"+s.mygrade + "subject:" + s.mysubject + "id:" + s.myID);
}
}
}
实验结果:
心得体会:
理解了类的排序,重写了排序函数,对接口有了更深的理解