//学生成绩排名
#include
struct Birthday{
int year;
int month;
int day;
};
struct Student{
char name[30];
int age;
structBirthday birthday;
double score;
};
int main() {
int x;
printf("请输入学生人数:\n");
scanf("%d", &x);
struct Student stu[x];
struct Student *p = stu;
printf("请输入学生的姓名年龄出生年月 成绩:\n");
for(int i = 0; i < x; i++){
scanf("%s%d%d%d%lf",\
(*(p+i)).name,\
&(*(p+i)).age, \
&(*(p+i)).birthday.year,\
&(*(p+i)).birthday.month, \
&(*(p+i)).score);
}
// 用数组b[z]接收所有学生的成绩
double b[x];
for (int z = 0; z < x; z++) {
b[z] = (*(p+z)).score;
}
//将所有学生的成绩重新排列,从b[0]开始依次减小(重复的排在一起)
for(int i = 0; i < x; i++){
for (int m = i+1; m < x; m++) {
if (b[i] < b[m]) {
int temp = b[i];
b[i] = b[m];
b[m] = temp;
} //i = 0时,将最大的排到b[0],以此类推
}
}
int t;
//用来记录重复成绩的个数
for (int j =0; j < x; j += t) { //j+=t,既去除了b[j]后面(t-1)与之重复的的成绩
t = 0; //每次都从0开始记录,否则不是同一个成绩的重复个数,而是所有的“打印”出来的个数
for (int i =0; i < x; i++) {
if((*(p+i)).score == b[j]) {
//(*(p+i))每次都是从第一个开始与固定的成绩比较,这样使已经比较出来的进行了重复比较,需要考虑怎么去除掉这些重复比较
//b[j],因为数组b[j]收集了所有学生的成绩,并且将所有的成绩进行了排列,从b[0]开始依次减小(相同的成绩排在一起),所以从b[0]开始选择成绩最好的,以此类推
printf("名次%d %s成绩为%.2f,生日是%d年%d月\n",\
j+1,
(*(p+i)).name, \
(*(p+i)).score, \
(*(p+i)).birthday.year, \
(*(p+i)).birthday.month);
t++; //去除b[j]中重复的,如果只有一个成绩等于b[j],t++= 1,进入下一个b[j+1],如果有n个成绩等于b[j],则t++ = n+1,则进入b[j+n+1],从而过滤掉前几个重复的
}
}
}
return 0;
}