1.本次实验由于要用到多组数据,所以要用到二维数组,同时学生姓名要与成绩相对应,所以还要创建字符串数组来存储名字。刚开始时使用的是char[][]的二维数组作为名字存储数组,但是在后面的排序函数中,总是会出现中断异常,还会输出异常的字符,经查询后,原因可能是缓冲区的问题。使用strcpy()复制数值字符数组时,还被提醒不安全。后面换成string后,就没有了这些错误情况,string类型可以用“=”来赋值。
2.本次实验重点是在排序算法,经典的有冒泡排序,插入排序,选择排序。但该实验的难点是需要将经过排序后的成绩与学生姓名相对应。原本的想法是创建一个新的数组,记录成绩数组下标的变动,然后就按照该数组的数据来输出姓名,具体方法是在循环中,每交换一次数值,中介值就加一。但后面发现效果并不理想。所以最后变为姓名数组随着成绩数组一起变动,使用swap()函数,进行两个字符串的交换。
3.当用原本的数组进行排序时,会导致原来的数据完全打乱。所以排序前,要创建数组的副本。特别是姓名字符串数组,每个成绩进行排序时,就必须重新复制一遍样本。
4.创建数组时指定数组大小的常数不能用变量。cin,cout 编译器会自动知道所用的变量类型。
endl是换行的作用