java演算法面試題:設計一個快速排序。雙路快速排序,簡單易於理解。

来源:https://www.cnblogs.com/qingyundian/archive/2018/01/28/8372873.html
-Advertisement-
Play Games

這是我的思路,應該屬於雙路快速排序的一種,快速排序的解決思路太多了,有單路、雙路、三路,每種的寫法也各有不同,每個人的思路都千奇百怪。 ...


package com.swift;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class QuickSort {
    /*
     * 快速排序
     */

    public static void main(String[] args) {
        int[] strVoid = new int[] { 11, 66, 22, 0, 55, 2, 0, 11 };
        QuickSort sort = new QuickSort();
        sort.quickSort(strVoid, 0, strVoid.length - 1);
        for (int i = 0; i < strVoid.length; i++) {
            System.out.println(strVoid[i] + " ");
        }
        // 用比較器排序
        List<Integer> list = new ArrayList<Integer>();
        for (Integer i : strVoid) {
            list.add(i);
        }
        Collections.sort(list, new Comparator<Integer>() {

            @Override
            public int compare(Integer arg0, Integer arg1) {
                int num = arg1 - arg0;
                return num;
            }

        });
        for (Integer i : list) {
            System.out.print(i + " | ");
        }
    }

    void quickSort(int[] strDate, int left, int right) {
        int i, j, t, key;
        if (left > right)
            return;

        key = strDate[left]; // temp中存的就是基準數
        i = left;
        j = right;
        while (i != j) {
            // 從後找比key小的或者等的放在key的左邊
            while (strDate[j] > key && i < j)
                j--;
            // 從前找比key大的放在key的右邊
            while (strDate[i] <= key && i < j)
                i++;
            // 小於就交換位置,等於就停止
            if (i < j) {
                t = strDate[i];
                strDate[i] = strDate[j];
                strDate[j] = t;
            }
        }
        // 兩指針相等後,將第一個位置的值與相等處位置的值互換,完成第一輪排序
        strDate[left] = strDate[i];
        strDate[i] = key;

        quickSort(strDate, left, i - 1);// 繼續處理左邊的,這裡是一個遞歸的過程
        quickSort(strDate, i + 1, right);// 繼續處理右邊的 ,這裡是一個遞歸的過程
    }
}

這是我的思路,應該屬於雙路快速排序的一種,快速排序的解決思路太多了,有單路、雙路、三路,每種的寫法也各有不同,每個人的思路都千奇百怪。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 作者: "nnngu" 項目源代碼:https://github.com/nnngu/nguSeckill 首先在編寫 層代碼前,我們應該首先要知道這一層到底是乾什麼的。 層主要負責業務模塊的邏輯應用設計。同樣是首先設計介面,再設計其實現的類,接著在 的配置文件中配置其實現的關聯。這樣我們就可以在應 ...
  • 使用正則表達式的幾個步驟: 1、用import re 導入正則表達式模塊; 2、用re.compile()函數創建一個Regex對象; 3、用Regex對象的search()或findall()方法,傳入想要查找的字元串,返回一個Match對象; 4、調用Match對象的group()方法,返回匹配 ...
  • redis的使用和安裝,redis基礎和高級部分 在後端開發中,為了提高性能,對於一些經常查詢但是又不太變化的內容會使用redis,比如前端的列表展示項等,如果數據有變化也可以清空緩存,讓前端查一次資料庫,所以使用redis相對高效和靈活.本文主要對於redis在linux上的使用和安裝進行說明。 ...
  • jsp jsp簡介: JSP全名為Java Server Pages,中文名叫java伺服器頁面,其根本是一個簡化的Servlet設計,在jsp中既可以寫html 代碼 ,又可以寫java代碼 作用:將頁面顯示與業務邏輯相分離; 通常分為三部分: java 代碼 html代碼 jsp指令 jsp本質 ...
  • 1.flask特有的變數和函數: 變數:g、session、request、config 函數:url_for()、get_flashed_messages()這個函數註意了啊,記住這是個函數,別忘了寫括弧!!!!!!!!! 廢話不多說,直接上代碼體驗一下: 先解釋一個bug,當我們設置了# -*- ...
  • ——————————————————————————————————————————————————————————————————————————————————————————— 本篇開始進入正題,因為涉及 MDL,所以相關的背景知識是必須的: nt!_MDL 代表一個“記憶體描述符鏈表”結構,它 ...
  • a=0#回車 print(a)#回車 輸出0 #複製下麵這一段開始 def funcA(): b='A'def funcB(): a=2 b='B' print(a,b) def funcC(): nonlocal a b='C' a=3 print(a,b) ... ...
  • 這是測試 Hhhhhhhhhhhhhhh Aaaaaaaaaaaaa Gggggggggggggggg ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...