zoukankan      html  css  js  c++  java
  • java基本算法之快速排序

    快速排序:是找出一个元素(理论上可以随便找一个)作为基准(pivot),然后对数组进行分区操作,使基准左边元素的值都不大于基准值,基准右边的元素值 都不小于基准值,如此作为基准的元素调整到排序后的正确位置。递归快速排序,将其他n-1个元素也调整到排序后的正确位置。最后每个元素都是在排序后的正 确位置,排序完成。所以快速排序算法的核心算法是分区操作,即如何调整基准的位置以及调整返回基准的最终位置以便分治递归。

    /**
    * 快速排序
    * 快速排序采用了分治策略。就是在一个数组中取一个基准数字,把小的数放基准的左边,大的数放基准的右边。
    * 基准左边和右边分别是新的序列。在新的序列中再取一个基准数字,小的放左边,大的放右边。
    * 这个里面用到的递归。我们需要三个参数,一个是数组,另外两个是序列的边界
    * @author shaomch
    */
    public class QuickSort {

    public void quickSort(int[] arr, int left, int right) {
      if (left >= right) {
        return;
      }
      int i = left;
      int j = right;
      int piovt = arr[left];// 基准数:数组的第一个数作为基准数
      while (i != j) {
        // 循环1:从数组右边开始循环,直到找到小于基准数的元素并且放在数组的右边。
        while (i < j && arr[j] >= piovt) {
          j--;
        }
        arr[i] = arr[j];
        // 循环2:从数组左边开始循环,直到找到大于基准数的元素并且放在数组的左边。
        while (i < j && arr[i] <= piovt) {
          i++;
        }
        arr[j] = arr[i];
      }
      arr[i] = piovt;
      quickSort(arr, left, i - 1);
      quickSort(arr, i + 1, right);
    }
    }

  • 相关阅读:
    sudo 临时切换用户和环境变量的传递
    递归复杂度算法如何计算草稿
    Mac下设计全局环境变量
    Golang http 超时设置方法
    go get github竟然区分大小写
    通过远程终端后台运行程序
    打开华为手机的logcat
    Golang的锁和线程安全的Map
    PL/SQL语句块基本语法(ORACLE存储过程,函数,包,游标) (转)
    C# 文件操作把结果保存到文件里
  • 原文地址:https://www.cnblogs.com/michaelShao/p/5607742.html
Copyright © 2011-2022 走看看