欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解如何在Java中實(shí)現(xiàn)堆排序算法

 更新時(shí)間:2022年03月25日 09:35:36   作者:之一Yo  
這篇文章主要為大家詳細(xì)介紹了如何利用Java實(shí)現(xiàn)堆排序算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

算法描述

堆排序算法的描述如下:

  • 將待排序的數(shù)組調(diào)整為最大堆,此時(shí)未排序的長(zhǎng)度 N 為數(shù)組的長(zhǎng)度,調(diào)整的過(guò)程就是倒序?qū)?shù)組的前 N/2 個(gè)元素下沉的過(guò)程,每次下沉都會(huì)將較大的元素帶到上面,最終將數(shù)組變?yōu)樽畲蠖眩?/li>
  • 彈出最大堆的堆頂元素并將其移動(dòng)到數(shù)組的最后面,將原本最后面的元素放到堆頂,然后將未排序的長(zhǎng)度 N - 1,調(diào)整數(shù)組的前 N 個(gè)元素為最大堆;
  • 重復(fù)步驟 2 直到未排序的長(zhǎng)度為 0.

實(shí)現(xiàn)代碼

package com.zhiyiyo.collection.sort;

import java.util.Arrays;

public class HeapSort extends BaseSort {
    @Override
    public void sort(Comparable[] array) {
        int N = array.length;

        // 創(chuàng)建最大堆
        for (int i = N / 2; i >= 0; i--) {
            sink(array, i, N);
        }

        // 就地排序
        while (N > 0) {
            // 將最大的元素移動(dòng)到數(shù)組的尾部,同時(shí)將未排序的長(zhǎng)度-1
            swap(array, 0, --N);
            // 調(diào)整最大堆
            sink(array, 0, N);
        }
    }

    /**
     * 下沉元素
     *
     * @param array 數(shù)組
     * @param k     下沉的元素索引
     */
    private void sink(Comparable[] array, int k, int N) {
        while (2 * k + 1 < N) {
            int j = 2 * k + 1;
            if (j < N - 1 && less(array[j], array[j + 1])) j++;
            if (!less(array[k], array[j])) break;
            swap(array, k, j);
            k = j;
        }
    }
}

抽象類 BaseSort 的代碼為:

package com.zhiyiyo.collection.sort;

/**
 * 數(shù)組排序抽象類
 */
public abstract class BaseSort {
    public abstract void sort(Comparable[] array);

    /**
     * 交換數(shù)組元素
     *
     * @param array 數(shù)組
     * @param a     數(shù)組下標(biāo) a
     * @param b     數(shù)組下標(biāo) b
     */
    protected static void swap(Comparable[] array, int a, int b) {
        Comparable tmp = array[a];
        array[a] = array[b];
        array[b] = tmp;
    }

    protected static boolean less(Comparable a, Comparable b) {
        return a.compareTo(b) < 0;
    }

}

測(cè)試代碼

package com.zhiyiyo.collection.sort;

import org.junit.Test;

import java.util.Arrays;


public class HeapSortTest {

    @Test
    public void sort() {
        Integer[] array = {5, 10, 9, 6, 8, 7, 2, 1, 4, 3};
        new HeapSort().sort(array);
        System.out.println(Arrays.toString(array));
    }
}

最終排序結(jié)果為 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10],以上~

到此這篇關(guān)于詳解如何在Java中實(shí)現(xiàn)堆排序算法的文章就介紹到這了,更多相關(guān)Java堆排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • springboot 實(shí)現(xiàn)Http接口加簽、驗(yàn)簽操作方法

    springboot 實(shí)現(xiàn)Http接口加簽、驗(yàn)簽操作方法

    這篇文章主要介紹了springboot 實(shí)現(xiàn)Http接口加簽、驗(yàn)簽操作,服務(wù)之間接口調(diào)用,通過(guò)簽名作為安全認(rèn)證來(lái)保證API的安全性,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-09-09
  • Java多線程中的CyclicBarrier詳解

    Java多線程中的CyclicBarrier詳解

    這篇文章主要介紹了Java多線程中的CyclicBarrier詳解,同步屏障,允許一組線程互相等待以到達(dá)一個(gè)公共的障礙點(diǎn),當(dāng)設(shè)定的線程數(shù)到達(dá)屏障時(shí),阻塞的線程繼續(xù)執(zhí)行,需要的朋友可以參考下
    2023-11-11
  • Java SSM框架如何配置靜態(tài)資源加載

    Java SSM框架如何配置靜態(tài)資源加載

    這篇文章主要介紹了Java SSM框架如何配置靜態(tài)資源加載,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 基于UncategorizedSQLException異常處理方案

    基于UncategorizedSQLException異常處理方案

    這篇文章主要介紹了基于UncategorizedSQLException異常處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 解決FileWriter 寫入文本不換行的問(wèn)題

    解決FileWriter 寫入文本不換行的問(wèn)題

    這篇文章主要介紹了解決FileWriter 寫入文本不換行的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 深入分析Java內(nèi)存區(qū)域的使用詳解

    深入分析Java內(nèi)存區(qū)域的使用詳解

    本篇文章對(duì)Java內(nèi)存區(qū)域的使用進(jìn)行了詳細(xì)的介紹。需要的朋友參考下
    2013-05-05
  • SpringBoot中如何對(duì)actuator進(jìn)行關(guān)閉

    SpringBoot中如何對(duì)actuator進(jìn)行關(guān)閉

    這篇文章主要介紹了SpringBoot中如何對(duì)actuator進(jìn)行關(guān)閉問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Springboot?通過(guò)FastJson實(shí)現(xiàn)bean對(duì)象和Json字符串互轉(zhuǎn)問(wèn)題

    Springboot?通過(guò)FastJson實(shí)現(xiàn)bean對(duì)象和Json字符串互轉(zhuǎn)問(wèn)題

    這篇文章主要介紹了Springboot?通過(guò)FastJson實(shí)現(xiàn)bean對(duì)象和Json字符串互轉(zhuǎn),本文嘗試驗(yàn)證兩種場(chǎng)景給大家詳細(xì)介紹,對(duì)Springboot?FastJson實(shí)現(xiàn)bean和Json互轉(zhuǎn)問(wèn)題,感興趣的朋友一起看看吧
    2022-08-08
  • 如何使用IDEA新建一個(gè)普通的Javaweb項(xiàng)目

    如何使用IDEA新建一個(gè)普通的Javaweb項(xiàng)目

    今天給大家普及如何使用IDEA新建一個(gè)普通的Javaweb項(xiàng)目及配置tomcat的方法,在文末給大家提到如果不想每次都重啟tomcat,可以設(shè)置快捷方式,對(duì)idea新建Javaweb項(xiàng)目感興趣的朋友一起看看吧
    2021-06-06
  • java雙重檢查鎖定的實(shí)現(xiàn)代碼

    java雙重檢查鎖定的實(shí)現(xiàn)代碼

    這篇文章主要介紹了java雙重檢查鎖定的實(shí)現(xiàn)方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06

最新評(píng)論