编写程序,输入n个学生的学号和成绩(有1位小数),按成绩从高到低排序输出,n 小于50,学号小于10位。
时间: 2023-08-31 08:38:17 浏览: 93
编写一个程序用来对学生评定成绩
### 回答1:
以下是 Python 代码实现:
```python
n = int(input("请输入学生人数:"))
students = []
for i in range(n):
student_id, score = input("请输入第{}个学生的学号和成绩(以空格隔开):".format(i+1)).split()
students.append((student_id, float(score)))
sorted_students = sorted(students, key=lambda x: x[1], reverse=True)
print("按成绩从高到低排序的结果如下:")
for student in sorted_students:
print("{} {}".format(student[0], student[1]))
```
这里使用了 Python 内置函数 `sorted()`,并指定了 `key` 参数,以便按照成绩从高到低排序。最后,使用 `for` 循环输出排序结果。
### 回答2:
编写这个程序首先需要一个学生类,属性包括学号和成绩。然后,我们可以使用一个容器(如列表)来存储所有学生的信息。
首先,程序需要用户输入学生的数量n。然后,使用一个循环,依次输入每个学生的学号和成绩,并将其存储在学生对象中,再将学生对象添加到容器中。
接下来,我们可以使用Python的sorted函数,通过指定成绩作为关键字进行排序,将学生对象从高到低排序。
最后,使用一个循环遍历已经排序好的学生对象列表,将学生的学号和成绩依次输出。
下面是一个可能的实现:
```python
# 定义学生类
class Student:
def __init__(self, id, score):
self.id = id
self.score = score
# 输入学生数量
n = int(input("请输入学生数量:"))
# 存储学生信息的容器
students = []
# 输入学生的学号和成绩,并将其添加到容器中
for i in range(n):
print("请输入第{}个学生的学号和成绩(用空格分隔):".format(i+1))
id, score = input().split()
student = Student(id, float(score))
students.append(student)
# 按成绩从高到低排序
students_sorted = sorted(students, key=lambda x: x.score, reverse=True)
# 输出排序后的学生信息
print("按成绩从高到低排序的学生信息:")
for student in students_sorted:
print("学号:{},成绩:{}".format(student.id, student.score))
```
这个程序能够接收用户输入的学生信息,并按照成绩从高到低进行排序和输出。
### 回答3:
编写程序实现上述功能可以使用排序算法,常用的排序算法有冒泡排序、选择排序、插入排序和快速排序等。这里选择使用冒泡排序来进行学生信息的排序。
首先,我们需要定义一个结构体Student,包含学号和成绩两个属性。然后,创建一个长度为n的Student类型的数组来存储学生信息。
接下来,按照以下步骤编写程序:
1. 首先,输入n个学生的学号和成绩,依次存储到数组中。
2. 使用冒泡排序,从数组中的第一个元素开始,比较每个元素与其后一个元素的成绩大小,如果后一个元素的成绩大于前一个元素,则交换它们的位置,直到最后一个元素。
3. 重复步骤2,直到所有的元素都按照成绩的降序排列。
4. 输出排序后的学号和成绩。
以下是使用C++语言编写的示例代码:
```cpp
#include <iostream>
using namespace std;
// 定义学生结构体
struct Student {
long long id; // 学号
float score; // 成绩
};
int main() {
int n;
cout << "请输入学生数量:";
cin >> n;
// 创建学生数组
Student students[n];
// 输入学生学号和成绩
for (int i = 0; i < n; i++) {
cout << "请输入第" << i+1 << "位学生的学号和成绩:";
cin >> students[i].id >> 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) {
// 交换位置
Student temp = students[j];
students[j] = students[j+1];
students[j+1] = temp;
}
}
}
// 输出排序后的学生学号和成绩
cout << "按成绩从高到低排序的学生信息:" << endl;
for (int i = 0; i < n; i++) {
cout << "学号:" << students[i].id << " 成绩:" << students[i].score << endl;
}
return 0;
}
```
使用这段代码,你可以根据需要的学生数量输入学号和成绩,并按照成绩从高到低的顺序输出学生信息。
阅读全文