解题思路:
1.定义结构体 2.循环输入数据 3.sort排序 4.输出第k名
注意事项:
参考代码:
#include <bits/stdc++.h> using namespace std; // 定义学生结构体 struct Student { int id; // 学号 float score; // 成绩 }; // 自定义比较函数,根据score字段比较学生记录 bool compare(const Student& a, const Student& b) { return a.score > b.score; // 按降序排列 } int main() { int n, k; cin >> n >> k; // 输入学生人数和要求的第k名学生 Student students[100]; // 定义学生记录数组,假设最多有100个学生 // 输入学生的学号和成绩 for (int i = 0; i < n; i++) { cin >> students[i].id; cin >> students[i].score; } // 按照成绩进行排序 sort(students, students + n, compare); // 输出第k名学生的学号和成绩 cout << students[k - 1].id << " " << students[k - 1].score << endl; return 0; }
0.0分
0 人评分
C二级辅导-阶乘数列 (C语言代码)浏览:642 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:600 |
破解简单密码 (C语言代码)浏览:1863 |
C二级辅导-等差数列 (C语言代码)浏览:1315 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:746 |
WU-整数平均值 (C++代码)浏览:1307 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:646 |
母牛的故事 (C语言代码)浏览:739 |
a+b浏览:452 |
1113题解浏览:823 |