c++3510 找出谁是第二高 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000MS 内存限制: 256MB 分数:100 OI排行榜得分:12(0.1*分数+2*难度) 数组 排序基础 第九讲(Level1) 描述 根据学生学号顺序(学号从1开始),输入n名学生的身高(身高无重复),找出其中身高第二高的同学。输出身高第二高的学生身高以及他的学号。 输入描述 一行一个正整数 n,代表学生人数。 一行 n 个正整数,代表学生身高h,数字之间使用空格分隔。 输出描述 一行两个正整数,代表第二高同学的学号,以及他的身高。内容之间使用空格间隔。 样例输入 1 8 110 116 144 134 160 105 159 137 样例输出 1 7 159 提示 数据范围与提示 5≤n≤100,110≤h≤200
以下是使用 C++ 解决此问题的代码: ```cpp #include <iostream> #include <vector> #include <algorithm> int main() { int n; std::cin >> n; std::vector<int> heights; for (int i = 0; i < n; ++i) { int height; std::cin >> height; heights.push_back(height); } std::sort(heights.begin(), heights.end()); int secondHighest = heights[n - 2]; for (int i = 0; i < n; ++i) { if (heights[i] == secondHighest) { std::cout << i + 1 << " " << secondHighest << std::endl; break; } } return 0; } ``` 额外需要注意的逻辑点: 1. 输入数据的有效性检查,例如是否为正整数。 2. 对于边界情况,如只有两个学生时的处理。 3. 考虑使用更高效的排序算法,如快速排序。 [2025-05-14 19:40:42 | AI写代码神器 | 254点数解答]
相关提问
- [字节豆包] 3510 找出谁是第二高 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000MS 内存限制: 256MB 分数:100 OI排行榜得分:12(0.1*分数+2*难度) 数组 排序基础 第九讲(Level1) 描述 根据学生学号顺序(学号从1开始),输入n名学生的身高(身高无重复),找出其中身高第二高的同学。输出身高第二高的学生身高以及他的学号。 输入描述 一行一个正整数 n,代表学生人数。 一行 n 个正整数,代表学生身高h,数字之间使用空格分隔。 输出描述 一行两个正整数,代表第二高同学的学号,以及他的身高。内容之间使用空格间隔。 样例输入 1 8 110 116 144 134 160 105 159 137 样例输出 1 7 159 提示 数据范围与提示 5≤n≤100,110≤h≤200(194点数解答 | 2025-05-14 19:40:08)150
- [字节豆包] c++3510 找出谁是第二高 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000MS 内存限制: 256MB 分数:100 OI排行榜得分:12(0.1*分数+2*难度) 数组 排序基础 第九讲(Level1) 描述 根据学生学号顺序(学号从1开始),输入n名学生的身高(身高无重复),找出其中身高第二高的同学。输出身高第二高的学生身高以及他的学号。 输入描述 一行一个正整数 n,代表学生人数。 一行 n 个正整数,代表学生身高h,数字之间使用空格分隔。 输出描述 一行两个正整数,代表第二高同学的学号,以及他的身高。内容之间使用空格间隔。 样例输入 1 8 110 116 144 134 160 105 159 137 样例输出 1 7 159 提示 数据范围与提示 5≤n≤100,110≤h≤200(254点数解答 | 2025-05-14 19:40:42)119
- [阿里通义] 查询分数2 c++ 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000ms 内存限制: 256mb 分数:100 oi排行榜得分:12(0.1*分数+2*难度) 数组 第十六讲(level1-1) 第八讲(level1) 描述 童程童美学院对某班级的n名同学进行了一次测试。要求编写程序:输入n名学生的成绩,以每名学生的学号作为输入的顺序( 学号从1开始)。再输入某名学生的学号,查询该名学生的成绩。 输入描述 三行; 一行一个正整数n,代表n名学生(1≤n≤100); 一行n个整数,表示n名学生的分数,数值之间使用空格分隔(0≤分数≤100); 一行一个正整数id,表示某名学生的学号(1≤id≤100)。 输出描述 一行一个整数,代表某名学生的成绩。(228点数解答 | 2024-12-05 19:24:38)180
- [百度文心] 查询分数2 c++ 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000ms 内存限制: 256mb 分数:100 oi排行榜得分:12(0.1*分数+2*难度) 数组 第十六讲(level1-1) 第八讲(level1) 描述 童程童美学院对某班级的n名同学进行了一次测试。要求编写程序:输入n名学生的成绩,以每名学生的学号作为输入的顺序( 学号从1开始)。再输入某名学生的学号,查询该名学生的成绩。 输入描述 三行; 一行一个正整数n,代表n名学生(1≤n≤100); 一行n个整数,表示n名学生的分数,数值之间使用空格分隔(0≤分数≤100); 一行一个正整数id,表示某名学生的学号(1≤id≤100)。 输出描述 一行一个整数,代表某名学生的成绩。(362点数解答 | 2024-12-05 19:26:12)461
- [字节豆包] 查询分数2 c++ 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000ms 内存限制: 256mb 分数:100 oi排行榜得分:12(0.1*分数+2*难度) 数组 第十六讲(level1-1) 第八讲(level1) 描述 童程童美学院对某班级的n名同学进行了一次测试。要求编写程序:输入n名学生的成绩,以每名学生的学号作为输入的顺序( 学号从1开始)。再输入某名学生的学号,查询该名学生的成绩。 输入描述 三行; 一行一个正整数n,代表n名学生(1≤n≤100); 一行n个整数,表示n名学生的分数,数值之间使用空格分隔(0≤分数≤100); 一行一个正整数id,表示某名学生的学号(1≤id≤100)。 输出描述 一行一个整数,代表某名学生的成绩。只用c++(200点数解答 | 2024-12-08 16:03:35)196
- [阿里通义] 查询分数 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000ms 内存限制: 256mb 分数:100 oi排行榜得分:12(0.1*分数+2*难度) 数组 第十五讲(level1-1) 第八讲(level1) 描述 从键盘输入5名学生的分数,保存在整型数组a中,根据输入的学号(学号从1开始),输出对应的分数。 输入描述 两行; 第一行5个整数,表示5名学生的分数(0≤分数≤100),数值之间使用空格分隔; 第二行1个正整数,表示要查询的学生学号id(1≤id≤5)。 输出描述 一行一个整数,代表要查询的分数。(227点数解答 | 2024-12-05 19:08:09)178
- [阿里通义] 查询分数 c++ 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000ms 内存限制: 256mb 分数:100 oi排行榜得分:12(0.1*分数+2*难度) 数组 第十五讲(level1-1) 第八讲(level1) 描述 从键盘输入5名学生的分数,保存在整型数组a中,根据输入的学号(学号从1开始),输出对应的分数。 输入描述 两行; 第一行5个整数,表示5名学生的分数(0≤分数≤100),数值之间使用空格分隔; 第二行1个正整数,表示要查询的学生学号id(1≤id≤5)。 输出描述 一行一个整数,代表要查询的分数。(188点数解答 | 2024-12-05 19:08:45)426
- [阿里通义] 查询分数 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000ms 内存限制: 256mb 分数:100 oi排行榜得分:12(0.1*分数+2*难度) 数组 第十五讲(level1-1) 第八讲(level1) 描述 从键盘输入5名学生的分数,保存在整型数组a中,根据输入的学号(学号从1开始),输出对应的分数。 输入描述(376点数解答 | 2024-12-05 19:07:36)170
- [字节豆包] 3414 数字游戏 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000ms 内存限制: 256mb 分数:100 oi排行榜得分:12(0.1*分数+2*难度) 字符串 第五讲(level1-2) 描述 小 k 同学向小 p 同学发送了一个长度为 8 的 01 字符串来玩数字游戏,小 p 同学想要知道字符串中究竟有多少个 1。 注意:01 字符串为每一个字符是 0 或者 1 的字符串,如“101”(不含双引号)为一个长度为 3 的 01 字符串。 输入描述 一个长度为 8 的 01 字符串 s。 输出描述 一个整数,即 01 字符串中字符 1 的个数。(106点数解答 | 2024-10-27 14:23:27)346
- [字节豆包] 题目描述 陶陶家的院子里有一棵苹果树,每到秋天树上就会结出 10 个苹果。苹果成熟的时候,陶陶就会跑去摘苹果。陶陶有个 30 厘米高的板凳,当她不能直接用手摘到苹果的时候,就会踩到板凳上再试试。 现在已知 10 个苹果到地面的高度,以及陶陶把手伸直的时候能够达到的最大高度,请帮陶陶算一下她能够摘到的苹果的数目。假设她碰到苹果,苹果就会掉下来。 输入格式 输入包括两行数据。第一行包含 10 个 100 到 200 之间(包括 100 和 200)的整数(以厘米为单位)分别表示 10 个苹果到地面的高度,两个相邻的整数之间用一个空格隔开。第二行只包括一个 100 到 120 之间(包含 100 和 120)的整数(以厘米为单位),表示陶陶把手伸直的时候能够达到的最大高度。 输出格式 输出包括一行,这一行只包含一个整数,表示陶陶能够摘到的苹果的数目。 输入样例1 100 200 150 140 129 134 167 198 200 111 110 输出样例1 5 用c++ 回答篇幅:简单明了(149点数解答 | 2025-10-29 20:10:13)41
- [字节豆包] 题目描述 午饭时间,喵喵喵幼儿园的n位小朋友从左到右排成一列等待领取自己的午餐。我们 将这些小朋友从左到右依次标号为 1,2,⋯,n−1,n。 负责配餐的老师已经拿到了所有人的午饭餐食,餐食同样也是从左到右排成一排。 老师手里拿到了一份序列 r1 ⋯rn,代表编号为i的小朋友应该拿到从左向右数第 ri份 午餐餐食(1≤ri≤n且 ri两两不同)。 按照上面的序列分发完成后,老师又拿到了一个序列 a1⋯an,其中 a i代表未分发前从 左向右数第 i 份餐食的一个参数。 老师想要知道,对每个小朋友,他们所拿到的午餐的这个参数的值是多少。但是这个 任务对于老师来说太难了,所以喵喵喵幼儿园找到了万能的你。 输入格式 共三行。 第一行一个整数,代表 n。 第二行 n 个整数,代表 r1⋯rn。 第三行 n 个整数,代表 a1⋯an。 输出格式 一行,n 个整数。第 i 个整数代表编号为 i 的小朋友所拿到的午餐的这个参数是多 少。 输入输出样例 输入 #1 4 4 1 3 2 7 4 2 9 输出 #1 9 7 2 4 说明/提示 样例解释 编号(481点数解答 | 2025-11-16 19:24:11)22
- [字节豆包] 300,0,144,1,0,0 300,0,144,0,1,0 300,0,144,0,0,1 300,0,144,1,1,0 300,0,108,0,1,1 184,0,72,1,0,1 184,0,72,0,0,0 184,0,72,0,0,0 184,0,72,0,0,0 184,1,72,1,0,1 184,1,72,0,0,0 184,1,72,0,0,0 184,1,72,0,0,0 184,1,72,0,0,0 184,1,720,0,0,0构建数据文件data.txt(377点数解答 | 2024-12-13 08:02:21)187