Java快排算法(java工程师需要掌握哪些知识)

思路对于给定的数组,从中选一个元素为比较对象,一般选最左或最右的元素,选左边为升序排,选右边反之。数组array[]:最左边:target=5数组下标:i=0,j=9步骤:①从右边遍历数组,把array[j]比5小的放在5的左边,j–;交换位置后i=0,j=7:②从左边遍历数组,把array[i]比5大的放在5的右边,i++;交换位置后i=…

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

思路

对于给定的数组,从中选一个元素为比较对象,一般选最左或最右的元素,选左边为升序排,选右边反之。

数组array[]:
在这里插入图片描述
最左边:target = 5
数组下标:i = 0, j = 9

步骤:

①从右边遍历数组,把array[ j ]比5小的放在5的左边, j–;
交换位置后i = 0,j = 7:

在这里插入图片描述

②从左边遍历数组,把array[ i ]比5大的放在5的右边, i++;
交换位置后i = 5,j = 7:

在这里插入图片描述

③回到①②步骤循环执行:
在这里插入图片描述

循环执行后,比5小的都放在了5的左边,比5大的都放在了5的右边;

④此时5左边和右边部分还是乱序的,这就需要做递归操作,把0 2 3 1 4和 7 8 6 9 部分继续执行述排序步骤。
递归执行后:

在这里插入图片描述

代码示例:

public class _06FastSortExample { 
   
    /** * 左右两个哨兵 * * @param left * @param right 每次都是这个先 */
    public void quicksort(int[] a, int left, int right) { 
   
        int i, j, t, temp;//哨兵i,哨兵j,交换ij用到t,基准数temp
        if (left > right) { 
   //跳出
            return;
        }
        //传过来的参数进行赋值
        temp = a[left];//temp中存储的就是基准数
        i = left;//左边哨兵
        j = right;//右边哨兵
        while (i != j) { 
   
            //顺序很重要,先从右边开始找
            while (a[j] >= temp && i < j) { 
   
                j--;//记录哨兵j位置
            }
            //再从左边找:小于基准数的数
            while (a[i] <= temp && i < j) { 
   
                i++;//记录哨兵i位置
            }
            //交换两个数在数组中的位置
            if (i < j) { 
   
                t = a[i];
                a[i] = a[j];
                a[j] = t;
            }
        }
        //最终将基准数归位 : 就是基准数跟ij相遇位置的数进行交换
        a[left] = a[i];//a[i]给left的位置也就是0,就是基准数
        a[i] = temp;//基准数该a[i]

        quicksort(a, left, i - 1);//继续处理左边的,这里是一个递归的过程
        quicksort(a, i + 1, right);//继续处理右边的 ,这里是一个递归的过程
    }

    public static void main(String[] args) { 
   
        int a[] = { 
   5,2,3,1,6,4,7,8,0,9};//数组//定义变量,这两个变量需要在子函数中使用
        _06FastSortExample f = new _06FastSortExample();
        f.quicksort(a, 0, a.length - 1);
        for (int aa : a) { 
   
            System.out.println(aa);
        }
    }
}

其他算法:

Java二分查找法
Java冒泡排序
Java选择排序
Java插入排序
Java希尔排序
Java计数排序
Java快排算法
Java归并排序
Java堆排序
动图演示

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

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

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


相关推荐

  • EasyBoot使用方法

    EasyBoot使用方法1修改背景图片直接替换掉EasyBoot\disk1\ezboot目录下面的BACK.BMP文件即可。但是限于DOS功能限制,只能使用640×480像素,256位色的BMP图片。2鼠标

    2022年7月4日
    20
  • 飞行器pid控制(旋翼飞控)

    先说下什么是四旋翼飞行器名称:四旋翼飞行器组件:一个机架,一个陀螺仪,四个无刷直流电机,一个电池,一块单片机(能飞起来的最基本配置)原理:利用四个电机旋转产生的反作用力托起飞行器上升,利用单片机和飞行控制算法控制电机使飞行器稳定然互简单介绍下串级PID算法名字:串级PID算法作用:采集飞行器姿态角,输出调控量是飞行器稳定先说一下姿态角,现在我们想象一个平铺在空间的一个“十”字,这个字左右晃,上下晃…

    2022年4月10日
    109
  • Drupal8 入门教程(一)安装部署

    Drupal8 入门教程(一)安装部署&#13; 一、Drupal简介  Drupal是使用PHP语言编写的开源内容管理框架(CMF),它由内容管理系统(CMS)和PHP开发框架(Framework)共同构成。连续多年荣获全球最佳CMS大奖,是基于PHP语言最著名的WEB应用程序。截止2011年底,共有13,802位WEB专家参加了Drupal的开发工作;228个国家使用181种语言的729,791位网站设计…

    2022年6月10日
    38
  • java旅游管理系统(带文档

    java旅游管理系统(带文档关注公众号,回复:java旅游管理系统,获取源码,百度云哦。不会安装,找公众号管理员

    2022年5月15日
    55
  • PLSQL下载、安装、配置、连接详细教程

    PLSQL下载、安装、配置、连接详细教程常用的几个基本sql: select*fromtablewhere范围 插入:insertintotable(field1,field2)values(value1,value2) 删除:deletefromtablewhere范围 更新:updatetablesetfield=valuewhere范围 查找:select*fromtablewh…

    2022年6月16日
    221
  • 谷歌高级搜索技巧_谷歌到底有多强大

    谷歌高级搜索技巧_谷歌到底有多强大强大的谷歌搜索技巧AlotofpeoplecommentonthetopofthemywifeandmyWeddingCake.Ithasmyself(wire-rimglasses,goatee,traditionalScotishKiltandSporin)andmywife(withTraditionalAfricanKe…

    2022年10月9日
    3

发表回复

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

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