C++优化选择排序实现从大到小排序
### 🔍思路分析 选择排序的基本思想是在未排序序列中找到最大(小)元素,存放到排序序列的起始位置。优化后的选择排序可以在每一轮同时找到最大和最小元素,分别放到未排序序列的两端,从而减少比较次数。 ### 💻代码实现 ```cpp #include <iostream> #include <vector> using namespace std; // 优化后的选择排序函数,从大到小排序 void optimizedSelectionSort(vector<int>& arr) { int left = 0, right = arr.size() - 1; while (left < right) { int maxIndex = left; int minIndex = right; for (int i = left; i <= right; i++) { if (arr[i] > arr[maxIndex]) { maxIndex = i; } if (arr[i] < arr[minIndex]) { minIndex = i; } } // 交换最大元素到左边 swap(arr[left], arr[maxIndex]); // 如果最小元素的位置刚好是原来最大元素的位置,修正最小元素的位置 if (minIndex == left) { minIndex = maxIndex; } // 交换最小元素到右边 swap(arr[right], arr[minIndex]); left++; right--; } } int main() { int n; cin >> n; vector<int> arr(n); for (int i = 0; i < n; i++) { cin >> arr[i]; } optimizedSelectionSort(arr); for (int i = 0; i < n; i++) { if (i > 0) { cout << " "; } cout << arr[i]; } cout << endl; return 0; } ``` ### 📝代码解释 1. **`optimizedSelectionSort`函数**: - 使用两个指针`left`和`right`分别指向未排序序列的左右两端。 - 在每一轮中,同时找到最大和最小元素的索引`maxIndex`和`minIndex`。 - 先将最大元素交换到`left`位置,再将最小元素交换到`right`位置。 - 每一轮结束后,`left`指针右移,`right`指针左移。 2. **`main`函数**: - 读取输入的整数`n`和`n`个整数,存储在`vector`中。 - 调用`optimizedSelectionSort`函数对数组进行排序。 - 输出排序后的数组,相邻元素用空格隔开。 ### ⚙️复杂度分析 - **时间复杂度**:$O(n^2)$,因为需要进行两轮嵌套的循环。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ### 🚀开发建议 - **边界条件检查**:在实际应用中,需要对输入的`n`进行有效性检查,确保`1 < n < 100`。 - **错误处理**:可以添加输入错误处理,例如输入非整数的情况。 - **代码复用**:将排序函数封装成独立的模块,方便在其他项目中复用。 ######[AI写代码神器 | 776点数解答 | 2026-03-20 19:54:05]
- 超详细:JDK安装及Windows系统环境变量设置全攻略 (阿里通义 | 376点数解答 | 2024-03-06 17:27:29)351
- 解析React 15与Vue 2:从O(n^3)到O(n),Diff算法时间复杂度计算及性能对比 (阿里通义 | 379点数解答 | 2023-11-09 01:49:19)331
- 缜密逻辑,全新无名杀“风餐”技能代码精心打造与深度解析 (字节豆包 | 469点数解答 | 2025-04-05 11:37:06)238
- 精准优化:明确需求,开启高效提升之旅! (字节豆包 | 52点数解答 | 2026-02-09 16:44:46)33
- 代码再升级:优化版“获取dump”代码,多机制保障数据读取与保存(字节豆包 | 734点数解答 | 2026-02-10 01:23:31)61
- 代码深度优化:全面检查异常、灵活读取内存,提升可读性与可维护性(字节豆包 | 959点数解答 | 2026-02-10 01:24:14)32
- 2 秒动画搞定!“好句子”如何稳停结束位置( | 456点数解答 | 2024-05-19 16:46:15)273
- PHP实训:从0到1搭建电商平台,收获技能与成长!(讯飞星火 | 674点数解答 | 2024-06-17 08:58:32)346
- PHP实训:搭建电商平台的实战之旅与收获反思 (讯飞星火 | 623点数解答 | 2024-06-17 08:59:26)338
- PHP 实训:从零打造电子商务平台,解锁开发全流程!(GPT | 1439点数解答 | 2024-06-17 09:00:18)295
- PHP实训:搭建电子商务平台全流程揭秘与收获(GPT | 1868点数解答 | 2024-06-17 09:02:00)286
- C++ 求解:最少操作次数让字符串无子串 “friend” (字节豆包 | 153点数解答 | 2024-08-17 16:29:54)476