C++实现车厢排序最少旋转次数计算
```cpp #include <iostream> #include <vector> using namespace std; // 交换相邻两节车厢的函数 void swapAdjacent(vector<int>& cars, int i) { int temp = cars[i]; cars[i] = cars[i + 1]; cars[i + 1] = temp; } // 计算最少旋转次数的函数 int minRotations(vector<int>& cars) { int n = cars.size(); int rotations = 0; // 冒泡排序思想,通过交换相邻元素来排序 for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (cars[j] > cars[j + 1]) { swapAdjacent(cars, j); rotations++; } } } return rotations; } int main() { int n; cin >> n; vector<int> cars(n); // 读取初始车厢顺序 for (int i = 0; i < n; i++) { cin >> cars[i]; } // 计算最少旋转次数 int result = minRotations(cars); cout << result << endl; return 0; } ``` ### 代码解释: 1. **`swapAdjacent` 函数**:该函数用于交换向量 `cars` 中相邻的两个元素。 2. **`minRotations` 函数**:使用冒泡排序的思想,通过比较相邻元素的大小,如果前一个元素比后一个元素大,则交换它们的位置,并记录交换的次数。 3. **`main` 函数**:首先读取车厢总数 `n`,然后读取初始的车厢顺序并存储在向量 `cars` 中。调用 `minRotations` 函数计算最少旋转次数,并输出结果。 ######[AI问答 | 454点数解答 | 2026-05-30 20:02:30]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)401
- 用 C++ 和 OpenCV 生成带随机偏移的圆周上的点:代码剖析(字节豆包 | 29点数解答 | 2024-11-06 23:40:42)282
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)366
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)111
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)78
- 解决代码WA问题:修改整数溢出问题后的计算代码(字节豆包 | 749点数解答 | 2026-05-10 16:20:03)27
- 修正代码解决计算 f(l, r) 和出现的 WA 问题(字节豆包 | 806点数解答 | 2026-05-10 16:21:37)29
- C语言实现多班级学生信息管理系统:含增删改查与多样排序功能(GPT | 2547点数解答 | 2024-12-15 22:08:58)382
- C语言实现学生信息管理系统:含增删改查与多种排序功能(GPT | 6408点数解答 | 2024-12-15 22:10:03)379
- sys_module 表结构与 Java 实体类 SysModule 详解(字节豆包 | 252点数解答 | 2025-04-09 10:54:17)225
- MySQL表与Java类:`sys_role` 的创建及实体类定义全解析(字节豆包 | 168点数解答 | 2025-04-10 14:39:47)230
- C++ 破解“国王游戏”弱化版:贪心排序算法巧求最少最大奖赏(DeepSeek | 550点数解答 | 2025-04-28 18:16:50)435