Java通過幾種經典的演算法來實現數組排序

来源:http://www.cnblogs.com/liuhongfeng/archive/2016/03/25/5306648.html
-Advertisement-
Play Games

Java實現數組排序 ...


Java實現數組排序

 

package com.souvc.hibernate.exp;
 
public class MySort {
 
    /**
    * 方法名:main</br>
    * 詳述:Java實現數組排序 </br>
    * 開發人員:liuhf </br>
    * 創建時間:2016-3-22  </br>
    * @param args
    * @throws 
    * @since V1.0
     */
    public static void main(String[] args) {
        int array[] = {45,32,54,12,43,65,11,3,43,6,33,90,44,1,178};
        MySort mySort = new MySort();
        mySort.insertSort(array);
        System.out.print("插入排序結果 :  ");
        mySort.printArray(array);
        System.out.println();
        mySort.bubbleSort(array);
        System.out.print("冒泡排序結果 :  ");
        mySort.printArray(array);
        mySort.qsort(array);
        System.out.println();
        System.out.print("快速排序結果 :  ");
        mySort.printArray(array);
        mySort.shellSort(array);
        System.out.println();
        System.out.print("希爾排序結果 :  ");
        mySort.printArray(array);
        mySort.selectSort(array);
        System.out.println();
        System.out.print("選擇排序結果 :  ");
        mySort.printArray(array);
    }
     
    /**
     * 直接插入排序
     * 基本思想:在要排序的一組數中,假設前面(n-1)[n>=2] 個數已經是排好順序的,現在要把第n個數插到前面的有序數中,使得這n個數也是排好順序的。如此反覆迴圈,直到全部排好順序
     */
    public void insertSort(int[] array){
        int temp=0;  
        for(int i=1;i<array.length;i++){  
           int j=i-1;  
           temp=array[i];  
           for(;j>=0&&temp<array[j];j--){  
               array[j+1]=array[j];                       //將大於temp的值整體後移一個單位  
           }  
           array[j+1]=temp;  
        } 
    }
     
    /**
     * 冒泡排序
     * 基本思想:在要排序的一組數中,對當前還未排好序的範圍內的全部數,自上而下對相鄰的兩個數依次進行比較和調整,讓較大的數往下沉,較小的往上冒。即:每當兩相鄰的數比較後發現它們的排序與排序要求相反時,就將它們互換。
     */
    public void bubbleSort(int[] array) {
        int temp;
        for(int i=0;i<array.length;i++){//趟數
          for(int j=0;j<array.length-i-1;j++){//比較次數
            if(array[j]>array[j+1]){
              temp=array[j];
              array[j]=array[j+1];
              array[j+1]=temp;
            }
          }
        }
    }
     
    /**
     * 快速排序
     * 基本思想:選擇一個基準元素,通常選擇第一個元素或者最後一個元素,通過一趟掃描,將待排序列分成兩部分,一部分比基準元素小,一部分大於等於基準元素,此時基準元素在其排好序後的正確位置,然後再用同樣的方法遞歸地排序劃分的兩部分。
     * @param array
     */
    public void qsort(int array[]){
        if(array.length>1){
            _qsort(array,0,array.length-1);
        }
    }
    /**
     * 一趟快速排序
     * @param array
     */
    private void _qsort(int[] array,int low,int high){
        if(low < high){
            int middle = getMiddle(array, low, high);
            _qsort(array,low,middle-1);
            _qsort(array, middle+1, high);
        }
    }
    /**
     * 得到中間值
     */
    private int getMiddle(int[] array,int low,int high){
        int tmp = array[low];
        while(low < high){
            while(low < high && array[high] >= tmp)
                high--;
            array[low] = array[high];
            while(low<high && array[low]<=tmp)
                low++;
            array[high] = array[low];
        }
        array[low] = tmp;
        return low;
    }
     
    /**
     * 簡單選擇排序
     * 基本思想:在要排序的一組數中,選出最小的一個數與第一個位置的數交換;然後在剩下的數當中再找最小的與第二個位置的數交換,如此迴圈到倒數第二個數和最後一個數比較為止。
     * @param array
     */
    public void selectSort(int[] array){
        int position=0;  
        for(int i=0;i<array.length;i++){  
               
            int j=i+1;  
            position=i;  
            int temp=array[i];  
            for(;j<array.length;j++){  
            if(array[j]<temp){  
                temp=array[j];  
                position=j;  
            }  
            }  
            array[position]=array[i];  
            array[i]=temp;  
        } 
    }
     
    /**
     * 希爾排序(最小增量排序)
     * 基本思想:演算法先將要排序的一組數按某個增量d(n/2,n為要排序數的個數)分成若幹組,每組中記錄的下標相差d.對每組中全部元素進行直接插入排序,然後再用一個較小的增量(d/2)對它進行分組,在每組中再進行直接插入排序。當增量減到1時,進行直接插入排序後,排序完成。
     * @param array
     */
    public  void shellSort(int[] array){  
        double d1=array.length;  
        int temp=0;  
        while(true){  
            d1= Math.ceil(d1/2);  
            int d=(int) d1;  
            for(int x=0;x<d;x++){  
                for(int i=x+d;i<array.length;i+=d){  
                    int j=i-d;  
                    temp=array[i];  
                    for(;j>=0&&temp<array[j];j-=d){  
                        array[j+d]=array[j];  
                    }  
                    array[j+d]=temp;  
                }  
            }  
            if(d==1)  
                break;  
        }  
    }  
     
    /**
     * 列印數組中的所有元素
     */
     
    public void printArray(int[] array){
        for (int i = 0; i < array.length; i++) {
            System.out.print(array[i]+" ");
        }
    }
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 1:表單提交controller獲得中文參數後亂碼解決方案 註意: jsp頁面編碼設置為UTF-8 form表單提交方式為必須為post,get方式下麵spring編碼過濾器不起效果 [html] view plain copy <%@ page language="java" import="ja ...
  • 設置註釋模板的入口: Window->Preference->Java->Code Style->Code Template 然後展開Comments節點就是所有需設置註釋的元素啦。現就每一個元素逐一介紹: 文件(Files)註釋標簽: 類型(Types)註釋標簽(類的註釋): 欄位(Fields) ...
  • 從昨天到現在,還依然停留在容器的學習上,現在寫常式代碼順手多了,看來寫代碼還是要多多練習才能有感覺。 經過一天的學習,有一下幾點知識點讓我覺得很有意義: (1)刪除容器中的元素的時候,pop_front和pop_back函數的返回值並不是刪除元素的值,而是void,即空數據類型,如果想要返回刪除的元 ...
  • 本文內容全部出自《Python基礎教程》第二版,在此分享自己的學習之路。 lxx___歡迎轉載:http://www.cnblogs.com/Marlowes/p/5312236.htmllxx___ Created on Xu Hoo 讀者已經知道了什麼是字元串,也知道如何創建它們。利用索引和分片 ...
  • 本人大一狗,內容僅為個人的初體會,有誤之處請見諒。 初學者可能剛接觸一些新名詞會感覺好像很厲害的樣子,有種不明覺厲的樣子。 比如多態,泛型,繼承,介面。其實這些也並不是很難,不要被名字所嚇到,不用怕,慢慢就會理解他了。 講一下多態,我認為多態是建立在繼承的基礎之上的。 我們想看看繼承。 這裡我們用了 ...
  • The Zen of Python, by Tim Peters Beautiful is better than ugly.Explicit is better than implicit.Simple is better than complex.Complex is better than c ...
  • 一、前言 本文主要測試redis實現session共用的實現方式,不討論如何讓nginx參與實現負載均衡等。 二、環境配置 本測試在Window下進行 三、安裝tomcat-redis-session-manager插件 1.源碼下載: 最新版源碼對jdk版本有要求,必須是JDk1.7,否則編譯通不 ...
  • Python的函數除了正常使用的必選參數外,還可以使用預設參數、可變參數和關鍵字參數。 預設參數 基本使用 預設參數就是可以給特定的參數設置一個預設值,調用函數時,有預設值得參數可以不進行賦值,如: 這樣調用power(5)時,相當於調用power(5, 2)。 設置預設參數時的註意事項: 一是必選 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...