```cpp #include <iostream> #include <vector> #include <algorithm> using namespace std; struct Team { int id; int depart; // 出发时间转换为分钟 int distance; // 路程时间转换为分钟 int arrive; // 到达时间 }; bool compare(const Team &a, const Team &b) { if (a.arrive != b.arrive) return a.arrive < b.arrive; if (a.depart != b.depart) return a.depart < b.depart; return a.id < b.id; } int timeToMinutes(const string &time) { int h = stoi(time.substr(0, 2)); int m = stoi(time.substr(3, 2)); return h * 60 + m; } int main() { int n; cin >> n; vector<Team> teams(n); for (int i = 0; i < n; ++i) { string depart, distance; cin >> depart >> distance; teams[i].id = i + 1; teams[i].depart = timeToMinutes(depart); teams[i].distance = timeToMinutes(distance); teams[i].arrive = teams[i].depart + teams[i].distance; } sort(teams.begin(), teams.end(), compare); for (const auto &team : teams) { cout << team.id << endl; } return 0; } ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 时间字符串转换为分钟时,注意字符串的格式和范围,确保小时在00-23之间,分钟在00-59之间。 2. 比较函数中要正确处理多个排序条件,确保优先级顺序正确(到达时间 > 出发时间 > 编号)。 3. 输入时注意数组索引从0开始,但题目要求编号从1开始输出,需要在存储时进行+1处理。 [2025-08-07 10:58:12 | AI写代码神器 | 432点数解答]