博客
关于我
1004 成绩排名 (20分)
阅读量:540 次
发布时间:2019-03-09

本文共 1471 字,大约阅读时间需要 4 分钟。

要解决这个问题,我们需要读取n名学生的姓名、学号和成绩,然后分别输出成绩最高和最低的学生的姓名和学号。以下是详细的解决方案:

方法思路

  • 读取输入:首先读取输入的学生数n,然后循环读取每一行,每行包括学生的姓名、学号和成绩。
  • 存储数据:将姓名、学号和成绩分别存储在向量中。
  • 寻找最大值和最小值:遍历成绩,记录最高和最低的成绩对应的学生信息。
  • 输出结果:分别输出成绩最高和最低学生的姓名和学号。
  • 解决代码

    #include 
    #include
    #include
    using namespace std;int main() { int n; cin >> n; vector
    names(n); vector
    nums(n); vector
    scores(n); for (int i = 0; i < n; ++i) { string line; getline(cin, line); size_t first_space = line.find(' '); size_t second_space = line.find(' ', first_space + 1); string name = line.substr(0, first_space); string num = line.substr(first_space + 1, second_space - first_space - 1); string score_str = line.substr(second_space + 1); int score = stoi(score_str); names[i] = name; nums[i] = num; scores[i] = score; } int max_score = scores[0]; int min_score = scores[0]; int max_index = 0; int min_index = 0; for (int i = 1; i < n; ++i) { if (scores[i] > max_score) { max_score = scores[i]; max_index = i; } if (scores[i] < min_score) { min_score = scores[i]; min_index = i; } } cout << names[max_index] << ' ' << nums[max_index] << endl; cout << names[min_index] << ' ' << nums[min_index] << endl; return 0;}

    代码解释

  • 读取输入:首先读取n的值,然后循环读取每一行信息。使用getline函数来读取每一行数据。
  • 分割姓名、学号和成绩:使用find方法找到字符串中的空格,分割出姓名、学号和成绩。
  • 转换成绩:将成绩字符串转换为整数,存储到scores向量中。
  • 寻找最高分和最低分:遍历成绩向量,记录最高分和最低分对应的学生索引。
  • 输出结果:根据记录的索引,分别输出最高分和最低分学生的姓名和学号。
  • 这种方法高效且直接,能够处理所有符合题目要求的输入情况。

    转载地址:http://fceiz.baihongyu.com/

    你可能感兴趣的文章
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询数据库所有表的字段信息
    查看>>
    【Java基础】什么是面向对象?
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>
    MySQL 死锁了,怎么办?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 添加列,修改列,删除列
    查看>>
    mysql 添加索引
    查看>>
    MySQL 添加索引,删除索引及其用法
    查看>>
    mysql 状态检查,备份,修复
    查看>>
    MySQL 用 limit 为什么会影响性能?
    查看>>