排序-快排算法对数组进行排序

目录

一、问题描述

二、解题思路

1.初始化

2.将右侧小于基准元素移到左边

3.将左侧大于基准元素移到右边

4.重复执行上面的操作

5.对分好的左、右分区再次执行分区操作

6.最终排序结果

三、代码实现

四、刷题链接


一、问题描述

二、解题思路

快排算法实现数组排序:快排的核心步骤是分区操作。

下面详细图解一次分区过程:

1.初始化

2.将右侧小于基准元素移到左边

赋值后相当于下面的情形:

3.将左侧大于基准元素移到右边

然后开始比较arr[low]和pivot的大小:(和上图作对比)

赋值后的数组为:

4.重复执行上面的操作

再次修改high(左移--),移动元素,再次修改low(右移++),移动元素;当low==high时停止,完成一次分区操作

5.对分好的左、右分区再次执行分区操作

分区返回的是中间元素位置,我们要对左、右两个子分区再次执行分区操作,每次分区都会确定一个中间位置(后序不会再变),当分区内元素都为1的时候,快排结束。

6.最终排序结果

三、代码实现

import java.util.*;

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 将给定数组排序
     * @param arr int整型一维数组 待排序的数组
     * @return int整型一维数组
     */
    public int[] MySort (int[] arr) {
        // 使用快排排序
        QuickSort(arr,0,arr.length-1);
        return arr;
    }
    public int partition(int[] arr,int low,int high){
        int pivot=arr[low];//分界元素
        //System.out.println("low:"+low+",high:"+high);

        while(low<high){
            while(arr[high]>=pivot){//右侧元素大于pivot不移动
                if(low==high){
                    break;
                }
                high--;
            }
            arr[low]=arr[high];//现在的arr[high]已经没有元素了
            while(arr[low]<=pivot){//左侧元素小于等于pivot不移动
                if(low==high){
                    break;
                }
                low++;
            }
            arr[high]=arr[low];
        }
        //此时low位置就是初始的分界元素应该在的位置
        arr[low]=pivot;
        return low;
    }
    public void QuickSort(int[] arr,int low,int high){
        int pivotIndex=partition(arr,low,high);
        if(low<pivotIndex-1){
            QuickSort(arr,low,pivotIndex-1);
        }
        if(high>pivotIndex+1){
            QuickSort(arr,pivotIndex+1,high);
        }
    }
}

快排算法里面要注意边界条件,这个好好思考一下。

如果考研的话可以写伪代码,边界条件可以考虑的少一点

排序算法相关代码-CSDN博客文章浏览阅读108次。【代码】排序算法相关代码。https://blog.csdn.net/hehe_soft_engineer/article/details/134235961下面是之前写的排序算法的C++实现,属于伪代码,应试的话可以参考一下:

四、刷题链接

排序_牛客题霸_牛客网

相关推荐

  1. 排序算法】之

    2024-06-13 19:10:02       62 阅读
  2. 排序思想-

    2024-06-13 19:10:02       28 阅读
  3. 常见排序算法,希尔,归并,堆

    2024-06-13 19:10:02       23 阅读
  4. 排序 - (quick sort)

    2024-06-13 19:10:02       60 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-13 19:10:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-13 19:10:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-06-13 19:10:02       87 阅读
  4. Python语言-面向对象

    2024-06-13 19:10:02       96 阅读

热门阅读

  1. 大模型日报2024-06-13

    2024-06-13 19:10:02       37 阅读
  2. 京准电钟|基于纳秒级的GPS北斗卫星授时服务器

    2024-06-13 19:10:02       35 阅读
  3. [12] 使用 CUDA 进行图像处理

    2024-06-13 19:10:02       30 阅读
  4. python替换word文件中的图片

    2024-06-13 19:10:02       37 阅读
  5. 2024.05.31 校招 实习 内推 面经

    2024-06-13 19:10:02       35 阅读
  6. Go版RuoYi

    2024-06-13 19:10:02       33 阅读
  7. 工具:安装R语言的R包的各种方法

    2024-06-13 19:10:02       29 阅读