分治法(數(shù)據(jù)結構及算法09)

基本思想:

將一個規(guī)模為N的問題闪檬,分解成K個規(guī)模較小的子問題星著,這些子問題相互獨立且月原問題性質相同。求解出子問題的解粗悯,合并得到原問題的解虚循。

一、查找技術
1、順序查找

如果線性表為無序表横缔,即表中元素的排列是無序的铺遂,則不管線性表采用順序存儲還是鏈式存儲,都必須使用順序查找茎刚。如果線性表有序襟锐,但采用鏈式存儲結構,則也必須使用順序查找膛锭。

2粮坞、二分查找
image.png

前題條件:數(shù)據(jù)已經排序
注意:設計成左閉右開--是一種區(qū)間無重復的思想random(0,1)等大量的數(shù)學函數(shù)for(int i=0;i<array.length;i++)

    /**
     * 二分查找
     */
    public static int binarySearch(int[] array,int fromIndex,int toIndex,int key){
        int low=fromIndex;
        int high=toIndex-1;
        while(low<=high){
            int mid=(low+high)/2;//取中間
            int midVal=array[mid];
            if(key>midVal){//去右邊找
                low=mid+1;
            }else if(key<midVal){//去左邊找
                high=mid-1;
            }else{
                return mid;
            }
        }
        return -(low+1);//low+1表示找不到時停在了第low+1個元素的位置
    }
測試代碼
        int array[] = {1,2,3,4,5,6,7,8};
        int index0 = binarySearch(array, 0, array.length, 0);
        int index1 = binarySearch(array, 0, array.length, 1);
        int index4 = binarySearch(array, 0, array.length, 4);
        int index8 = binarySearch(array, 0, array.length, 8);
        System.out.println("0的下標:"+index0);
        System.out.println("1的下標:"+index1);
        System.out.println("4的下標:"+index4);
        System.out.println("8的下標:"+index8);
打印結果
0的下標:-1
1的下標:0
4的下標:3
8的下標:7
二初狰、快速排序(前序)
image.png

應用場景:數(shù)據(jù)量大并且是線性結構
短處:有大量重復數(shù)據(jù)的時候莫杈,性能不好,單向鏈式結構處理性能不好(一般來說,鏈式都不使用)

    //快速排序     31  21  59  68  12  40
    //    x=31
    public static void quickSort(int[] array,int begin,int end){
        if(end-begin<=0) return;
        int x=array[begin];
        int low=begin;//0
        int high=end;//5
        //由于會從兩頭取數(shù)據(jù)奢入,需要一個方向
        boolean direction=true;
        L1:
        while(low<high){
            if(direction){//從右往左找
                for(int i=high;i>low;i--){
                    if(array[i]<=x){
                        array[low++]=array[I];
                        high=I;
                        direction=!direction;
                        continue L1;
                    }
                }
                high=low;//如果上面的if從未進入姓迅,讓兩個指針重合
            }else{
                for(int i=low;i<high;i++){
                    if(array[i]>=x){
                        array[high--]=array[I];
                        low=I;
                        direction=!direction;
                        continue L1;
                    }
                }
                low=high;
            }
        }
        //把最后找到的值 放入中間位置
        array[low]=x;
        //開始完成左右兩邊的操作
        quickSort(array,begin,low-1);
        quickSort(array,low+1,end);
    }
測試代碼
        int arrays[] = {0,2,3,4,5,6,9,7,1};
        quickSort(arrays,0,arrays.length-1);
        for (int i = 0; i < arrays.length; i++) {
            System.out.print(arrays[i]+" ");
        }
打印結果
0 1 2 3 4 5 6 7 9 
三、歸并排序(后序)
image.png

應用場景:數(shù)據(jù)量大并且有很多重復數(shù)據(jù)俊马,鏈式結構
短處:需要空間大

public static void merge(int[] array,int left,int mid,int right){
        int leftSize=mid-left;
        int rightSize=right-mid+1;
        //生成數(shù)組
        int[] leftArray=new int[leftSize];
        int[] rightArray=new int[rightSize];
        //填充數(shù)據(jù)
        for(int i=left;i<mid;i++){
            leftArray[i-left]=array[i];
        }
        for(int i=mid;i<=right;i++){
            rightArray[i-mid]=array[i];
        }
        //合并
        int i=0;
        int j=0;
        int k=left;
        while(i<leftSize && j<rightSize){
            if(leftArray[i]<rightArray[j]){
                array[k]=leftArray[i];
                k++;i++;
            }else{
                array[k]=rightArray[j];
                k++;j++;
            }
        }
        while(i<leftSize){
            array[k]=leftArray[i];
            k++;i++;
        }
        while(j<rightSize){
            array[k]=rightArray[j];
            k++;j++;
        }
    }
public static void mergeSort(int array[],int left,int right){
        if(left==right){
            return;
        }else{
            int mid=(left+right)/2;
            mergeSort(array,left,mid);
            mergeSort(array,mid+1,right);
            merge(array,left,mid+1,right);
        }
    }
        int[] array=new int[]{2,1,6,4,3,9,8,10,7,5};
        mergeSort(array,0,array.length-1);
        for (int i : array) {
            System.out.print(i+" ");
        }
打印結果
1 2 3 4 5 6 7 8 9 10 
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末丁存,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子柴我,更是在濱河造成了極大的恐慌解寝,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,997評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件艘儒,死亡現(xiàn)場離奇詭異聋伦,居然都是意外死亡,警方通過查閱死者的電腦和手機界睁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評論 3 392
  • 文/潘曉璐 我一進店門觉增,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人翻斟,你說我怎么就攤上這事逾礁。” “怎么了访惜?”我有些...
    開封第一講書人閱讀 163,359評論 0 353
  • 文/不壞的土叔 我叫張陵嘹履,是天一觀的道長。 經常有香客問我债热,道長砾嫉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,309評論 1 292
  • 正文 為了忘掉前任窒篱,我火速辦了婚禮焕刮,結果婚禮上舶沿,老公的妹妹穿的比我還像新娘。我一直安慰自己配并,他們只是感情好括荡,可當我...
    茶點故事閱讀 67,346評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著荐绝,像睡著了一般。 火紅的嫁衣襯著肌膚如雪避消。 梳的紋絲不亂的頭發(fā)上低滩,一...
    開封第一講書人閱讀 51,258評論 1 300
  • 那天,我揣著相機與錄音岩喷,去河邊找鬼恕沫。 笑死,一個胖子當著我的面吹牛纱意,可吹牛的內容都是我干的婶溯。 我是一名探鬼主播,決...
    沈念sama閱讀 40,122評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼偷霉,長吁一口氣:“原來是場噩夢啊……” “哼迄委!你這毒婦竟也來了?” 一聲冷哼從身側響起类少,我...
    開封第一講書人閱讀 38,970評論 0 275
  • 序言:老撾萬榮一對情侶失蹤叙身,失蹤者是張志新(化名)和其女友劉穎堆生,沒想到半個月后夷都,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 45,403評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡曹铃,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,596評論 3 334
  • 正文 我和宋清朗相戀三年残吩,在試婚紗的時候發(fā)現(xiàn)自己被綠了财忽。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,769評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡泣侮,死狀恐怖即彪,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情活尊,我是刑警寧澤祖凫,帶...
    沈念sama閱讀 35,464評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站酬凳,受9級特大地震影響惠况,放射性物質發(fā)生泄漏。R本人自食惡果不足惜宁仔,卻給世界環(huán)境...
    茶點故事閱讀 41,075評論 3 327
  • 文/蒙蒙 一稠屠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦权埠、人聲如沸榨了。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽龙屉。三九已至,卻和暖如春满俗,著一層夾襖步出監(jiān)牢的瞬間转捕,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評論 1 269
  • 我被黑心中介騙來泰國打工唆垃, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留五芝,地道東北人。 一個月前我還...
    沈念sama閱讀 47,831評論 2 370
  • 正文 我出身青樓辕万,卻偏偏與公主長得像枢步,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子渐尿,可洞房花燭夜當晚...
    茶點故事閱讀 44,678評論 2 354