-
题目描述:
-
有N个学生的数据,将学生数据按成绩高低排序,如果成绩相同则按姓名字符的字母序排序,如果姓名的字母序也相同则按照学生的年龄排序,并输出N个学生排序后的信息。
-
输入:
-
测试数据有多组,每组输入第一行有一个整数N(N<=1000),接下来的N行包括N个学生的数据。
每个学生的数据包括姓名(长度不超过100的字符串)、年龄(整形数)、成绩(小于等于100的正数)。
-
输出:
-
将学生信息按成绩进行排序,成绩相同的则按姓名的字母序进行排序。
然后输出学生信息,按照如下格式:
姓名 年龄 成绩
-
样例输入:
-
3 abc 20 99 bcd 19 97 bed 20 97
-
样例输出:
-
bcd 19 97 bed 20 97 abc 20 99
之前老是用冒泡排序,感觉方便,写了篇快速排序之后,咱也得用起来,上AC代码
#include <stdio.h> #include <stdlib.h> #include <string.h> struct student{ char name[101]; int age; int grade; }; int partition(struct student *A, int left, int right); void quicksort(struct student *A, int begin, int end); int main() { struct student students[1001]; int i, n; while(scanf("%d",&n) != EOF) { //学生成绩赋值 for(i = 0; i < n; i ++) { scanf("%s%d%d",students[i].name, &students[i].age, &students[i].grade); } //快速排序 quicksort(students, 0, n-1); //打印输出 for(i = 0; i < n; i ++) { printf("%s %d %d\n",students[i].name, students[i].age, students[i].grade); } } return 0; } void quicksort(struct student *A, int begin, int end) { int pivot; if(begin < end) { pivot = partition(A, begin, end); quicksort(A, begin, pivot - 1); quicksort(A, pivot + 1, end); } } int partition(struct student *A, int left, int right) { struct student stand = A[left]; while(left < right) { while(left < right && (A[right].grade > stand.grade || (A[right].grade == stand.grade && strcmp(A[right].name,stand.name) > 0) || (A[right].grade == stand.grade && strcmp(A[right].name,stand.name) == 0 && A[right].age > stand.age ) ) ) { right --; } if(left < right) { A[left ++] = A[right]; } while(left < right && (A[left].grade < stand.grade || (A[left].grade == stand.grade && strcmp(A[left].name,stand.name) < 0) || (A[left].grade == stand.grade && strcmp(A[left].name,stand.name) == 0 && A[left].age < stand.age ) ) ) { left ++; } if(left < right) { A[right --] = A[left]; } } A[left] = stand; return left; }