一、功能说明:
给定一个学生类,其中包括成绩、科目和学号,根据课程成绩grade将学生进行排序。
二、设计流程:
第一步:创建一个学生类,其中包含成绩、科目和学号等信息。
第二步:创建一个接口,用于比较任意两个对象。
第三步:定义一个集合类,输出排好序后的结果。
三、关键源码:
1、定义学生类和一个用于比较的接口:
public class Student : IComparable
{
public double mygrade;
public string mysubject, myID;
public Student(double grade, string subject, string id)
{
mygrade = grade;
mysubject = subject;
myID = id;
}
int IComparable.CompareTo(object obj){
if(obj is Student)
{
Student NewObj = (Student)obj;
if (this.mygrade > NewObj.mygrade)
return 1;
else if (this.mygrade < NewObj.mygrade)
return -1;
else
return 0;
}
throw new ArgumentException("object is not a Student");
}
}
2、主函数:
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);
}
}
四、结果截图:
![](https://img-blog.csdnimg.cn/img_convert/6c5814ab0c7b364d7cdde27c568deabd.png)
五、总结:
本次作业是有关对象集合如何排序的,通过这次作业,让我初步了解到了c#中的对象集合和接口,明白了对象集合与数组之间的区别--对象集合无需声明元素类型,大小不用固定,可根据需要动态调整大小,较数组相比更为灵活。