返回顶部
首页 > 资讯 > 后端开发 > Python >java版十大排序经典算法:完整代码(3)
  • 443
分享到

java版十大排序经典算法:完整代码(3)

2024-04-02 19:04:59 443人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录归并排序完整代码:插入排序完整代码:希尔排序完整代码:总结归并排序 简单解释:该算法是采用分治法,把数组不断分割,直至成为单个元素,然后比较再合并(合并的过程就是两部分分别从头

归并排序

简单解释:该算法是采用分治法,把数组不断分割,直至成为单个元素,然后比较再合并(合并的过程就是两部分分别从头开始比较,取出最小或最大元素的放到新的区域内,继续取两部分中最大或最小的元素,直到这两部分合并完,最后所有的都合并完,最后形成完整的有序序列)

完整代码:


package com.keafmd.Sequence;

public class MergeSort {
    //归并排序
    public static void mergeSort(int []arr ,boolean ascending){
        int[] temp = new int[arr.length]; //在排序前,先建好一个长度等于原数组长度的临时数组,避免递归中频繁开辟空间
        mergeSort(arr,0,arr.length-1,temp,ascending);
    }
    public static void mergeSort(int []arr){
        mergeSort(arr,true);
    }
    
    public static void mergeSort(int []arr,int left,int right,int[] temp,boolean ascending){
        if(left<right){ //这里是递归结束的条件,我们是对半分,那当left==right的时候肯定大家都是只有一个元素了。
            //对半分,比如总长度是10,left=0,right=9,mid=4确实是中间分了,0~4,5~9
            //当长度9,left=0,right=8,mid=4,0~4,5~8
            int mid = left + (right-left)/2; // 防止越界的写法
            //int mid = (left+right)/2;
            mergeSort(arr,left,mid,temp,ascending); //左边归并排序,使得左子序列有序
            mergeSort(arr,mid+1,right,temp,ascending); //右边归并排序,使得右子序列有序
            merge(arr,left,mid,right,temp,ascending); //将两个有序子数组合并操作
        }
    }
    private static void merge(int[] arr,int left,int mid,int right,int[] temp,boolean ascending){
        int i = left; //左序列起始下标
        int j = mid+1; //右序列起始下标
        int t = 0; //临时数组指针
        while(i<=mid&&j<=right){
            if(ascending?arr[i]<arr[j]:arr[i]>arr[j]){ //比较两个序列第一个元素谁小,谁小先拷贝谁到temp,然后对应子序列下标加1
                temp[t++] = arr[i++];
            }else {
                temp[t++] = arr[j++];
            }
        }
        while(i<=mid){ //将左边剩余元素填充进temp中——左序列有一些数总是比右边的大的数
            temp[t++] = arr[i++];
        }
        while(j<=right){ //将右序列剩余元素填充进temp中——右序列有一些数总是比左边的大的数
            temp[t++] = arr[j++];
        }
        t = 0;
        //将temp中的元素全部拷贝到原数组中
        while(left<=right){
            arr[left++] = temp[t++];
        }
    }
}

插入排序

简单解释:最简单的理解就是打地主时我们拿到牌后的整理过程,从第二个牌(假设我们拿起来这个牌开始比较)开始,(说下升序)从后往前比较如果比前面的那个牌小,就把牌往后移动,直到找到一个合适的位置(这个位置的前面的那个牌不比这个要放下的牌大)就把这个牌放到这个位置,慢慢的前面的部分变得有序,直至全部有序即可。

完整代码:


package com.keafmd.Sequence;

public class StraghtInsertSort {
    //插入排序
    public static void straghtInsertSort(int[] arr) {
        straghtInsertSort(arr, true);//默认进行升序
    }
    public static void straghtInsertSort(int[] arr, boolean ascending) {
        for (int i = 1; i < arr.length; i++) {
            int temp = arr[i];
            int j=0; //这就是那个合适的位置
            for (j = i - 1; j >= 0 && (ascending ? temp < arr[j] : temp > arr[j]); j--) {
                arr[j + 1] = arr[j];
            }
            //把牌放下,为啥是j+1,
            //是因为上面的循环遍历到不符合情况的时候 j是合适的位置的前面的那个数的位置
            //有点拗口,但是就是这个意思,看图方便理解下
            arr[j + 1] = temp;

        }
    }
}

希尔排序

简单解释:希尔排序是插入排序的改进版,我们理解一个叫做下标差的的东西,也就是下面那个图中的增量d,初始下标差为arr.length/2,然后继续/2,对在同一下标差(相当于把这几个数单独拿出来了)的若干个数进行插入排序即可。

完整代码:


package com.keafmd.Sequence;

public class shellSort {
    public static void shellSort(int[] arr) {
        shellSort(arr,true);
    }
    public static void shellSort(int[] arr,boolean ascending) {
        for(int d = arr.length/2;d>0;d/=2){
            for(int i=d;i< arr.length;i++){
                int temp = arr[i];
                int j=0;
                for(j=i-d;j>=0&&(ascending?temp<arr[j]:temp>arr[j]);j-=d){
                    arr[j+d]=arr[j];
                }
                arr[j+d] = temp;
            }
        }
    }
}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注编程网的更多内容!

--结束END--

本文标题: java版十大排序经典算法:完整代码(3)

本文链接: https://lsjlt.com/news/131194.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • java版十大排序经典算法:完整代码(3)
    目录归并排序完整代码:插入排序完整代码:希尔排序完整代码:总结归并排序 简单解释:该算法是采用分治法,把数组不断分割,直至成为单个元素,然后比较再合并(合并的过程就是两部分分别从头...
    99+
    2024-04-02
  • java版十大排序经典算法:完整代码
    目录十大排序算法对比冒泡排序完整代码:测试代码:运行结果:快速排序完整代码:总结十大排序算法对比 关于最后一列的稳定性,我稍微解释下,例如对序列:1 2 4 2 6 排序,序列中...
    99+
    2024-04-02
  • java版十大排序经典算法:完整代码(2)
    目录快速排序完整代码:直接选择排序完整代码:堆排序完整代码:总结快速排序 简单解释: 快速排序就是每次找一个基点(第一个元素),然后两个哨兵,一个从最前面往后走,一个从最后面往前面...
    99+
    2024-04-02
  • java版十大排序经典算法:完整代码(4)
    目录计数排序完整代码:桶排序完整代码:基数排序完整代码:完整测试类总结计数排序 简单解释:这个排序算法看名字也很好理解,就是就是额外找个数组来计数,然后在这个数组从小到大或从大到小...
    99+
    2024-04-02
  • Java十大经典排序算法图解
    目录0、算法概述0.1算法分类0.2算法复杂度0.3相关概念1、冒泡排序(BubbleSort)1.1算法描述1.2动图演示1.3代码实现2、选择排序(SelectionSort)2...
    99+
    2024-04-02
  • Java十大经典排序算法的实现图解
    目录前言一、排序算法1.排序算法概述(百度百科)2.《数据结构与算法》中的排序算法3.算法分析二、十大经典排序算法(Java开发版)1.冒泡排序2.快速排序3.基数排序4.插入排序5...
    99+
    2024-04-02
  • 怎么用java代码经典排序算法
    本篇内容主要讲解“怎么用java代码经典排序算法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用java代码经典排序算法”吧!排序算法是《数据结构与算法》中最基本的算法之一。排序算法可以分为...
    99+
    2023-06-17
  • Python怎么实现十大经典排序算法
    这篇“Python怎么实现十大经典排序算法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python怎么实现十大经典排序算法...
    99+
    2023-06-29
  • Python 十大经典排序算法实现详解
    目录关于时间复杂度关于稳定性名词解释1、冒泡排序(1)算法步骤(2)动图演示(3)Python 代码2、选择排序(1)算法步骤(2)动图演示(3)Python 代码3、插入排序(1)...
    99+
    2024-04-02
  • 可能是你看过最全的十大排序算法详解(完整版代码)
    目录前言交集排序冒泡简单快速排序插入排序直接插入排序希尔排序选择排序简单选择排序堆排序归并排序二路多路非比较类计数排序桶排序基数排序最后前言 兄弟们,应上篇数据结构的各位要求,今天我...
    99+
    2024-04-02
  • Java经典排序算法源码分析
    本篇内容主要讲解“Java经典排序算法源码分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java经典排序算法源码分析”吧!1.1 快速排序快速排序,一种排序很快的方法,使用分治思想,就是说快...
    99+
    2023-07-05
  • 七大经典排序算法图解
    目录插入排序①直接插入排序基本思想动图演示代码实现②希尔排序基本思想图示代码实现选择排序③直接选择排序基本思想动图演示代码实现④堆排序基本思想建堆需要注意的问题图示代码实现交换排序⑤...
    99+
    2024-04-02
  • 冒泡排序(Java)(完整代码)
       推荐我平时练习代码的工具,不用打开eclipse或者idea那么麻烦。 菜鸟工具 冒泡排序无非就是俩个for循环。 内嵌的for是用来求出当前数组最大或最小的那个元素 第一for是用来循环查找次最大的元素直到全部排序好。 先静态化创...
    99+
    2023-09-25
    算法 排序算法 数据结构
  • Python 数据结构之十大经典排序算法一文通关
    目录1、冒泡排序算法演示算法步骤算法实现2、选择排序算法演示算法步骤算法实现3、简单插入排序算法演示算法步骤算法实现4、希尔排序算法演示算法步骤算法实现5、归并排序算法演示算法步骤算...
    99+
    2024-04-02
  • JAVA十大排序算法之堆排序详解
    目录堆排序知识补充二叉树满二叉树完全二叉树二叉堆代码实现时间复杂度算法稳定性思考总结堆排序 这里的堆并不是JVM中堆栈的堆,而是一种特殊的二叉树,通常也叫作二叉堆。它具有以下特点: ...
    99+
    2024-04-02
  • JAVA十大排序算法之桶排序详解
    目录桶排序代码实现时间复杂度算法稳定性总结桶排序 桶排序是计数排序的升级,计数排序可以看成每个桶只存储相同元素,而桶排序每个桶存储一定范围的元素,通过函数的某种映射关系,将待排序数组...
    99+
    2024-04-02
  • Java十大排序算法之堆排序刨析
    二叉堆是完全二叉树或者是近似完全二叉树。 二叉堆满足二个特性︰ 1.父结点的键值总是大于或等于(小于或等于)任何一个子节点的键值。 2.每个结点的左子树和右子树都是一个二叉堆(都是最...
    99+
    2024-04-02
  • JAVA十大排序算法之冒泡排序详解
    目录冒泡排序代码实现代码实现时间复杂度算法稳定性总结冒泡排序 1.从数组头开始,比较相邻的元素。如果第一个比第二个大(小),就交换它们两个 2.对每一对相邻元素作同样的工作,从开始第...
    99+
    2024-04-02
  • JAVA十大排序算法之选择排序详解
    目录选择排序代码实现动图演示代码实现时间复杂度算法稳定性总结选择排序 1.找到数组中最大(或最小)的元素 2.将它和数组的第一个元素交换位置(如果第一个元素就是最大(小)元素那么它就...
    99+
    2024-04-02
  • JAVA十大排序算法之插入排序详解
    目录插入排序代码实现动图演示代码实现时间复杂度算法稳定性总结插入排序 当我们在玩扑克牌的时候,总是在牌堆里面抽取最顶部的一张然后按顺序在手中排列。 插入排序是指在待排序的元素中,假设...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作