Java快排实现(java快速排序代码)

快速排序:基本实现思路取一个标准位置的数字用其他位置的数字和标准数进行对比如果比标准数大则放到标准数的右边,如果比标准数小则放到标准数的左边然后使用递归进行持续比对(注意:递归要有入口如果当前数组有数据并且多个才进行排序),然后我们用代码实现packagesort;importjava.util.Arrays;/***Created…

大家好,又见面了,我是你们的朋友全栈君。

快速排序:

基本实现思路  取一个标准位置的数字  用其他位置的数字和标准数进行对比  如果比标准数大  则放到标准数的右边,如果比标准数小  则放到标准数的左边    然后使用递归进行持续比对 (注意:递归要有入口  如果当前数组有数据并且多个才进行排序) ,然后我们用代码实现

package sort;

import java.util.Arrays;

/**
 * Created by xiaobai on 2019/4/1.
 *
 * @author xiaobai.
 * @DATE 2019/4/1
 */
public class kuaiPai {

    public static void main(String[] args) {
        int[] arr = new int[]{5, 3, 4, 1, 6, 322, 66, 2, 78};
        quickSort(arr, 0, arr.length - 1);
        System.out.println(Arrays.toString(arr));
    }


    public static void quickSort(int[] arr, int start, int end) {

        //当开始位置小于结束位置时(数组有数据)  进行排序  也就是递归入口
        if (start < end) {
            //首先找到基准数  作为比较的标准数  取数组开始位置   从哪里开始  用哪个数当标准数 这个就是标准数
            int stard = arr[start];
            //记录需要进行排序的下标
            int low = start;
            int high = end;

            //循环比对比标准数大和小的数字
            while (low < high) {
                //如果标准数小于右边的数字  把右边的游标卡尺向左移动
                while (low < high && stard <= arr[high]) {
                    high--;
                }
                //如果标准数大于 右边的数字
                //用低位数字替换右边数字
                arr[low] = arr[high];
                //如果左边的数字比标准数小
                while (low < high && arr[low] <= stard) {
                    low++;
                }
                //如果左边的数字比标准数大
                //用左边数字替换右边数字
                arr[high] = arr[low];
            }
            //把标准数赋给高或者低所在的元素
            arr[low] = stard;
            //处理所有比标准数小的数字
            quickSort(arr, start, low);
            //处理所有比标准数大的数字
            quickSort(arr, low + 1, end);
        }
    }
}

互勉

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128138.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Django(59)验证和授权「建议收藏」

    Django(59)验证和授权「建议收藏」验证和授权概述Django有一个内置的授权系统。他用来处理用户、分组、权限以及基于cookie的会话系统。Django的授权系统包括验证和授权两个部分。验证是验证这个用户是否是他声称的人(比如用户名

    2022年7月31日
    2
  • JavaWeb防止表单重复提交的几种方式

    JavaWeb防止表单重复提交的几种方式JavaWeb防止表单重复提交的几种方式

    2022年4月22日
    110
  • SQLite 下载与安装「建议收藏」

    SQLite 下载与安装「建议收藏」一,安装1.到sqlite官网下载压缩包https://www.sqlite.org/download.html下载后是下面这2个文件:解压到同一目录,如图:”安装”完成后,在cmd下,执行sqlite3验证下是否安装正常。若不正常则需要添加系统环境变量,以便命令行式的操作。二,安装管理工具官网:http://sqlitestudio.pl或直接访问下载https://github.com/pawelsalawa/sqlitestudi…

    2022年10月24日
    1
  • Hadoop生态系统-一般详细

    Hadoop生态系统-一般详细首先我们先了解一下Hadoop的起源。然后介绍一些关于Hadoop生态系统中的具体工具的使用方法。如:HDFS、MapReduce、Yarn、Zookeeper、Hive、HBase、Oozie、Mahout、Pig、Flume、Sqoop。Hadoop的起源DougCutting是Hadoop之父,起初他开创了一个开源软件Lucene(用Java语言编写,提供了全文检索引擎的架构,与Goog…

    2022年5月19日
    42
  • JS字符串截取函数slice(),substring(),substr()的区别

    JS字符串截取函数slice(),substring(),substr()的区别JS字符串截取函数slice(),substring(),substr()的区别在JS中,slice()、substring()、substr()都有截取字符串的作用,那他们有哪些用法上的区别呢?如果你也有疑惑,这篇文章或许能够帮助到你。一、substring()substring()方法返回一个索引和另一个索引之间的字符串,语法如下:str.substring…

    2022年6月2日
    27
  • SOA/软件架构设计—面向服务的架构(SOA详细解释)「建议收藏」

    SOA/软件架构设计—面向服务的架构(SOA详细解释)「建议收藏」文章比较多,但干货慢慢,请耐心阅读面向服务的架构迄今为止,对于面向服务的架构(Service-OrientedArchitecture,SOA)还没有一个公认的定义。许多组织从不同的角度和不同的侧面对SOA进行了描述,较为典型的有以下三个:(1)W3C的定义:SOA是一种应用程序架构,在这种架构中,所有功能都定义为独立的服务,这些服务带有定义明确的可调用接口…

    2022年7月24日
    17

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号