快速排序(为什么不叫二分排序呢)
2023-12-14 15:33:30
干完工作的时候突然想起来快速排序我一直没学,就去看了一下别人写的博客,用的就是二分查找的思想,而且感觉挺像插入排序的。
插入排序是寻找最大,小值,而快排是确定一个数的左右区域。
package com.qx;
import java.util.Arrays;
/**
* @program: springBoot
* @author: quxiao
* @create: 2023-12-13 11:03
**/
public class t1 {
public static void main(String[] args) {
int[] ints = {9, 1, 5, 2, 7, 4, 123, 4, 2, 3, 6, 7, 8, 4, 2, 34, 23, 1113, 432, 11, 2, 3, 9};
}
private static void fastSort(int[] arr) {
//确定快排的思想(用升序作为例子)
//1、在需要排序的数中,选择一个 t 作为参照,我们要达到的效果是,t的左边小于他,t的右边大于它。这样就算排序好一个数。
//2、需要用一个双指针,【 l下标对应的数(arr[l])和t判断,约定小于或等于t 】,【r下标对应的数(arr[r])和t判断,约定大于或等于t】
//3、一旦l(arr[l])或者r(arr[r])不满足,对应的移动就停止
//4、参照数的归位,首先得确认查找数是应该在哪里,如果取的是arr[l],那就和l交换,如果取的是arr[r]那就和r交换。
dfs(arr, 0, arr.length - 1);
System.out.println(Arrays.toString(arr));
}
/**
* @param arr 待排序数组
* @param l 开始
* @param r 结束
*/
private static void dfs(int[] arr, int l, int r) {
if (l > r) {
return;
}
int tl, tr, t;
t = arr[l];
//之所以要存起来最初的开始、结束位置。是为了确定下一次的开始,结束位置。
tl = l;
tr = r;
while (l < r) {
while (arr[r] >= t && l < r) {
r--;
}
while (arr[l] <= t && l < r) {
l++;
}
if (l < r) {
int p = arr[r];
arr[r] = arr[l];
arr[l] = p;
}
}
arr[tl] = arr[l];
arr[l] = t;
//参照数的左边
dfs(arr, tl, l - 1);
//参照数的右边
dfs(arr, l + 1, tr);
}
}
文章来源:https://blog.csdn.net/qx020814/article/details/134995616
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!