用C语言编译一下给出班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出。 输入格式: 第一行为n (0 < n < 50),表示班里的学生数目; 第二行n个数,表示n个学生的成绩 ,成绩为一个不大于100的非负整数。 输出格式: 把成绩单按分数从高到低的顺序进行排序并输出,成绩之间有一个空格,最后的成绩后没空格。 输入样例: 在这里给出一组输入。例如: 4 80 90 92 28 输出样例: 在这里给出相应的输出。例如: 92 90 80 28
时间: 2024-02-01 07:16:41 浏览: 30
```c
#include <stdio.h>
#include <stdlib.h>
// 比较函数,用于qsort函数排序
int cmp(const void *a, const void *b) {
return *(int *)b - *(int *)a;
}
int main() {
int n;
scanf("%d", &n);
int a[50];
for (int i = 0; i < n; ++i) {
scanf("%d", &a[i]);
}
qsort(a, n, sizeof(int), cmp); // 排序
for (int i = 0; i < n; ++i) {
printf("%d", a[i]);
if (i != n - 1) {
printf(" ");
}
}
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>
#define MAX_STUDENTS 1000
#define MAX_NAME_LEN 50
typedef struct {
char name[MAX_NAME_LEN];
int score;
} Student;
void bubbleSort(Student students[], int n) {
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)) {
Student temp = students[j];
students[j] = students[j + 1];
students[j + 1] = temp;
}
}
}
}
int main() {
Student students[MAX_STUDENTS];
int n;
printf("请输入学生人数:");
scanf("%d", &n);
printf("请输入每个学生的姓名和成绩(中间用空格隔开):\n");
for (int i = 0; i < n; i++) {
scanf("%s %d", students[i].name, &students[i].score);
}
bubbleSort(students, n);
printf("排序后的成绩单为:\n");
for (int i = 0; i < n; i++) {
printf("%s %d\n", students[i].name, students[i].score);
}
return 0;
}
```
这段代码实现了一个简单的冒泡排序算法,用于按照成绩从高到低排序学生信息。如果成绩相同,则按照姓名的字典序进行排序。你可以根据自己的需求对代码进行修改和扩展。