80分,求改错
/*
某考试有5道题和1道附加题,每题最高得分20分,总分计算为所有题目分数之和。
给出一组考生的数据,对其按照总分从高到低进行排名,总分相同时按附加题得分高者优先。
输入说明
第一行为一个整数N,表示考生个数(N小于100),后面N行为考生数据,
每行包含考生姓名(长度不超过20个字符)以及6个以空格分隔的整数,
分别表示第一题到第五题以及附加题的得分(最后一项)。
输出说明
输出排序结果,每行为一个考生的姓名、总分、附加题得分,以空格分开。
输入样例
3
Kavin 20 20 20 20 20 18
Jony 18 20 20 20 20 20
Kaku 15 15 15 15 15 15
输出样例
Jony 118 20
Kavin 118 18
Kaku 90 15
*/
#include
struct students
{
char name[21];
int a, b, c, d, e, f, sum;
};
int main()
{
int i, j, n;
scanf("%d", &n);
struct students stu[100], s, t;
for (i=0; i"%s %d %d %d %d %d %d", stu[i].name, &stu[i].a,
&stu[i].b, &stu[i].c, &stu[i].d, &stu[i].e, &stu[i].f);
stu[i].sum=stu[i].a+stu[i].b+stu[i].c+stu[i].d+stu[i].e+stu[i].f;
}
for (i=0; i-1; i++)
{
for (j=i+1; j0; i-1; i++)
{
if (stu[i].sum==stu[i+1].sum && stu[i].f1].f)
{
t=stu[i];
stu[i]=stu[i+1];
stu[i+1]=t;
}
}
for (i=0; i"%s %d %d\n", stu[i].name, stu[i].sum, stu[i].f);
}
return 0;
}
for (i=0; i<n-1; i++)
{
for (j=i+1; j<n; j++)
{
if (stu[i].sum<stu[j].sum)
{
s=stu[i];
stu[i]=stu[j];
stu[j]=s;
}
}
}
for (i=0; i<n-1; i++)
{
if (stu[i].sum==stu[i+1].sum && stu[i].f<stu[i+1].f)
{
t=stu[i];
stu[i]=stu[i+1];
stu[i+1]=t;
}
}
改为:
for (i=0; i<n-1; i++)
{
for (j=i+1; j<n; j++)
{
if (stu[i].sum<stu[j].sum || (stu[i].sum==stu[j].sum && stu[i].f<stu[j].f))
{
s=stu[i];
stu[i]=stu[j];
stu[j]=s;
}
}
}
你的结构体里含有字符串,可以直接这样等号赋值吗,怎么老感觉怪怪的
你最好还是重新搞个指针数组来排序
#include <stdio.h>
#include <string.h>
struct student
{
char name[21];
int a, b, c, d, e, f, sum;
};
int main()
{
int n;
scanf("%d", &n);
// 定义一个结构体数组,用于存储考生的信息
struct student students[100];
// 读入每个考生的信息
for (int i = 0; i < n; i++)
{
scanf("%s %d %d %d %d %d %d", students[i].name, &students[i].a,
&students[i].b, &students[i].c, &students[i].d, &students[i].e, &students[i].f);
students[i].sum = students[i].a + students[i].b + students[i].c + students[i].d + students[i].e + students[i].f;
}
// 使用冒泡排序法按总分从大到小排序
for (int i = 0; i < n - 1; i++)
{
for (int j = i + 1; j < n; j++)
{
// 如果前一个考生的总分小于后一个考生的总分,交换两个考生的信息
if (students[i].sum < students[j].sum)
{
struct student temp = students[i];
students[i] = students[j];
students[j] = temp;
}
}
}
// 再次使用冒泡排序法按附加题分数从大到小排序
for (int i = 0; i < n - 1; i++)
{
for (int j = i + 1; j < n; j++)
{
// 如果前一个考生的总分与后一个考生的总分相同,且前一个考生的附加题分数小于后一个考生的附加题分数,交换两个考生的信息
if (students[i].sum == students[j].sum && students[i].f < students[j].f)
{
struct student temp = students[i];
students[i] = students[j];
students[j] = temp;
}
}
}
// 输出排序结果
for (int i = 0; i < n; i++)
{
printf("%s %d %d\n", students[i].name, students[i].sum, students[i].f);
}
return 0;
}