用C语言编译以下代码给出班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出。 输入格式: 第一行为n (0 < n < 50),表示班里的学生数目; 第二行n个数,表示n个学生的成绩 ,成绩为一个不大于100的非负整数。 输出格式: 把成绩单按分数从高到低的顺序进行排序并输出,成绩之间有一个空格,最后的成绩后没空格。 输入样例: 在这里给出一组输入。例如: 4 80 90 92 28 输出样例: 在这里给出相应的输出。例如: 92 90 80 28
时间: 2024-01-22 17:17:46 浏览: 112
```c
#include <stdio.h>
int main() {
int n, i, j;
scanf("%d", &n);
int a[n];
for (i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
for (i = 0; i < n; i++) {
for (j = i + 1; j < n; j++) {
if (a[i] < a[j]) {
int t = a[i];
a[i] = a[j];
a[j] = t;
}
}
}
for (i = 0; i < n - 1; i++) {
printf("%d ", a[i]);
}
printf("%d", a[n - 1]);
return 0;
}
```
相关问题
给出班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出,如果有相同分数则名字字典序小的在前。C语言
好的,下面是代码实现:
```c
#include <stdio.h>
#include <string.h>
struct student {
char name[20];
int score;
};
void sort(struct student stu[], int n) {
int i, j;
struct student temp;
for (i = 0; i < n - 1; i++) {
for (j = i + 1; j < n; j++) {
if (stu[i].score < stu[j].score || (stu[i].score == stu[j].score && strcmp(stu[i].name, stu[j].name) > 0)) {
temp = stu[i];
stu[i] = stu[j];
stu[j] = temp;
}
}
}
}
int main() {
int i, n;
struct student stu[100];
printf("请输入学生个数:");
scanf("%d", &n);
printf("请依次输入学生的姓名和成绩:\n");
for (i = 0; i < n; i++) {
scanf("%s %d", stu[i].name, &stu[i].score);
}
sort(stu, n);
printf("排序后的成绩单为:\n");
for (i = 0; i < n; i++) {
printf("%s %d\n", stu[i].name, stu[i].score);
}
return 0;
}
```
以上代码实现了按成绩从高到低排序,如果成绩相同则按名字字典序小的在前排序。
用c语言写个程序:给出班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出,如果有相同分数则名字字典序小的在前。...
好的,以下是用C语言编写的程序,实现对成绩单的排序:
```c
#include <stdio.h>
#include <string.h>
struct Student {
char name[20];
int score;
} students[100];
int main() {
int n;
printf("请输入学生人数:");
scanf("%d", &n);
printf("请依次输入学生姓名和成绩:\n");
for (int i = 0; i < n; i++) {
scanf("%s %d", students[i].name, &students[i].score);
}
// 冒泡排序
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (students[j].score < students[j + 1].score ||
(students[j].score == students[j + 1].score &&
strcmp(students[j].name, students[j + 1].name) > 0)) {
struct Student temp = students[j];
students[j] = students[j + 1];
students[j + 1] = temp;
}
}
}
printf("排序后的成绩单:\n");
for (int i = 0; i < n; i++) {
printf("%s %d\n", students[i].name, students[i].score);
}
return 0;
}
```
程序中定义了一个结构体 `Student`,包含了学生的姓名和成绩。首先通过输入学生人数和每个学生的姓名和成绩,将学生信息存储在 `students` 数组中。然后使用冒泡排序对成绩单进行排序,如果成绩相同则按照字典序小的在前。最后输出排序后的成绩单。
希望这个程序能够帮到您,有问题可以随时问我哦!
阅读全文