酷代码 AI
菜单
服务商

C++ 3510:如何从学生身高中精准找出第二高的学生及学号?

以下是使用 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. 考虑使用更高效的排序算法,如快速排序。 ######[AI写代码神器 | 254点数解答 | 2025-05-14 19:40:42]

相关提问
本站限时免费提问中
实用工具查看更多
Linux在线手册 [开发类]
Jquery在线手册 [开发类]
今日油价 [生活类]
图片互转base64 [开发类]
时间转换器 [开发类]