C++实现第一轮冒泡排序交换次数计算
### 🍭解题思路 冒泡排序的基本思想是比较相邻的元素,如果顺序错误就把它们交换过来。在第一轮冒泡排序中,我们从数组的第一个元素开始,依次比较相邻的两个元素,如果前一个元素大于后一个元素,就交换它们的位置,同时记录交换的次数。 ### 💻代码实现 ```cpp #include <iostream> using namespace std; int main() { int n; // 读取元素个数 cin >> n; int a[1000]; // 读取数组元素 for (int i = 0; i < n; i++) { cin >> a[i]; } int swapCount = 0; // 第一轮冒泡排序 for (int i = 0; i < n - 1; i++) { if (a[i] > a[i + 1]) { // 交换元素 int temp = a[i]; a[i] = a[i + 1]; a[i + 1] = temp; // 交换次数加1 swapCount++; } } // 输出交换次数 cout << swapCount << endl; return 0; } ``` ### 📋代码解释 1. **输入部分**:首先读取元素的个数`n`,然后读取`n`个非负整数存储在数组`a`中。 2. **第一轮冒泡排序**:使用一个`for`循环遍历数组,比较相邻的元素,如果前一个元素大于后一个元素,就交换它们的位置,并将交换次数`swapCount`加1。 3. **输出部分**:输出第一轮冒泡排序中元素交换的次数。 ### ⚙️复杂度分析 - **时间复杂度**:$O(n)$,因为只进行了一轮冒泡排序,需要遍历`n - 1`个元素。 - **空间复杂度**:$O(n)$,主要用于存储输入的数组。 ### 💡开发建议 - **边界条件检查**:在实际开发中,需要考虑输入的合法性,例如`n`的范围是否合理,输入的元素是否为非负整数等。 - **代码复用**:可以将冒泡排序的逻辑封装成一个函数,提高代码的复用性。 ######[AI写代码神器 | 533点数解答 | 2026-03-29 11:39:03]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)346
- C++ 实现:轻松找出 n 个整数中的第二小值(字节豆包 | 260点数解答 | 2026-02-07 21:19:29)27
- C++实现找出数组中第二小的值(字节豆包 | 526点数解答 | 2026-03-27 19:40:26)6
- 找出数组中第二小值的C++代码实现(字节豆包 | 696点数解答 | 2026-03-28 19:40:41)6
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)316
- C++ 代码实现自定义运算 x@y = x² + y² - xy 及 x@(x+y) 计算(DeepSeek | 215点数解答 | 2025-12-13 15:08:14)75
- C++ 实现根据输入正整数奇偶性计算偶数和或约数和(字节豆包 | 838点数解答 | 2026-02-28 20:23:59)28
- 揭秘:1 到 n 排列 p 变单调递增的最少操作次数(字节豆包 | 208点数解答 | 2024-10-19 19:39:33)170
- C语言揭秘:字符串排序函数 `sortstring` 详细解析(讯飞星火 | 1092点数解答 | 2024-11-27 08:08:34)200
- C 语言代码:补充函数实现变量值交换及注意要点揭秘(字节豆包 | 174点数解答 | 2024-12-12 00:37:54)165
- C语言实现多班级学生信息管理系统:含增删改查与多样排序功能(GPT | 2547点数解答 | 2024-12-15 22:08:58)360
- C语言实现学生信息管理系统:含增删改查与多种排序功能(GPT | 6408点数解答 | 2024-12-15 22:10:03)352