已解决
数据结构——排序算法——插入排序
来自网友在路上 159859提问 提问时间:2023-09-20 03:56:19阅读次数: 59
最佳答案 问答题库598位专家为你答疑解惑
交换法插入排序
void swap(vector<int> arr, int i, int j)
{int temp = arr[i];arr[i] = arr[j];arr[j] = temp;}void insertSort(vector<int> arr)
{// 从第二个数开始,往前插入数字for (int i = 1; i < arr.size(); i++) {// j 记录当前数字下标int j = i;// 当前数字比前一个数字小,则将当前数字与前一个数字交换while (j >= 1 && arr[j] < arr[j - 1]) {swap(arr, j, j - 1);// 更新当前数字下标j--;}}
}
移动法插入排序
void insertSort2(vector<int> arr)
{// 从第二个数开始,往前插入数字for (int i = 1; i < arr.size(); i++) {int currentNumber = arr[i];int j = i - 1;// 寻找插入位置的过程中,不断地将比 currentNumber 大的数字向后挪while (j >= 0 && currentNumber < arr[j]) {arr[j + 1] = arr[j];j--;}// 两种情况会跳出循环:1. 遇到一个小于或等于 currentNumber 的数字,跳出循环,currentNumber 就坐到它后面。// 2. 已经走到数列头部,仍然没有遇到小于或等于 currentNumber 的数字,也会跳出循环,此时 j 等于 -1,currentNumber 就坐到数列头部。arr[j + 1] = currentNumber;}
}
查看全文
99%的人还看了
相似问题
猜你感兴趣
版权申明
本文"数据结构——排序算法——插入排序":http://eshow365.cn/6-9757-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!
- 上一篇: 理解策略模式
- 下一篇: Spring 依赖注入和循环依赖