排序算法Java實(shí)現(xiàn)

快速排序

    /**
    * 第一次劃分大小
    * @param array
    * @param start
    * @param end
    * @return 掃描完畢指針的位置
    */
    public int once(int[] array,int start,int end){
        int i= start, j= end, temp=0;
        while( i< j){
            //右側(cè)掃描
            while( i< j && array[ i]<= array[ j])
            j--;
            //較小的數(shù)置于前面
            if( i< j){
                temp= array[ i];
            array[ i]= array[ j];
            array[ j]= temp;
            i++;
                 }
            //左側(cè)掃描
            while( i< j && array[ i]<= array[ j])
            i++;
        //較大的數(shù)置于后面
        if( i< j){
            temp= array[ i];
            array[ i]= array[ j];
            array[ j]= temp;
            j--;
        }
       }
        return i; //返回記錄的位置
    }

    public void quickSort( int[] array, int start, int end){
        //int location;
        if( start< end){
            int location = once( array, start, end);
            quickSort( array, start, location-1);
            quickSort( array, location+1, end);
        }
    }

冒泡排序

     /**
      * 冒泡排序算法
      * @param array 待排序數(shù)組
      */
     public void bubble(int[] array){
        for( int i=1; i< array.length; i++)
            for( int j=0; j< array.length- i; j++){
                if( array[j]> array[j+1]){
                    int t = array[j];
                    array[j] = array[j+1];
                    array[j+1] = t;
                }
            }
        }
    }

堆排序

    //篩選法調(diào)整堆
    public void Sift(int r[], int k, int m){
        int i, j, temp;
        i= k;
        j=2* i+1; //置i為要篩的結(jié)點(diǎn),j為i的左孩子
        while (j<=m){
            if (j< m && r[j] < r[j+1])
                  j++; //比較i的左右孩子,j為較大者
            if (r[i]> r[j]) 
                break; //根結(jié)點(diǎn)已經(jīng)大于左右孩子中的較大者
            else{
                temp = r[i];
                r[i] = r[j];
                r[j] = temp; //將根結(jié)點(diǎn)與結(jié)點(diǎn)j交換
                i = j;
                j = 2*i+1; //被篩結(jié)點(diǎn)位于原來(lái)結(jié)點(diǎn)j的位置
            }
        }
    }
    //堆排序
    public void heapSort(int r[ ], int n){
        int i;
        int temp;
        //初始建堆,從最后一個(gè)非終端結(jié)點(diǎn)至根結(jié)點(diǎn)
        for (i=n/2; i>=0; i--)
          Sift( r, i, n);
        //重復(fù)執(zhí)行移走堆頂及重建堆的操作
        for (i=n-1; i>0; i--){
              temp= r[ i];
              r[ i]= r[0];
              r[0]= temp;
           Sift( r, 0, i-1);
        }
    }

選擇排序

    /**
    *
    * @param array 待排序數(shù)組
    * @param n 數(shù)組長(zhǎng)度
    */
    public void selectSort( int[] array, int n){
        /**
        * i 無(wú)序區(qū)中第一個(gè)位置
        * j 中間變量
        * index 無(wú)序區(qū)中第一個(gè)位置吨枉,用于與無(wú)序區(qū)的其他r[j]進(jìn)行比較
        * temp 用于交換變量
        */
        int i, j, index, temp;
        //對(duì)n個(gè)記錄進(jìn)行n-1趟簡(jiǎn)單選擇排序
        for (i=0; i< n-1; i++){
            index = i;
            //在無(wú)序區(qū)中選取最小記錄
            for (j= i+1; j< n; j++)          
                if (array[j] < array[index])
            index = j;
            if (index!= i){
                temp = array[i];
                array[i]= array[index];
                array[index]= temp;
            }
        }
    }

歸并排序(待續(xù)...)

如發(fā)現(xiàn)錯(cuò)誤岭埠,還望不吝指正為謝~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市置森,隨后出現(xiàn)的幾起案子肥矢,更是在濱河造成了極大的恐慌端衰,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件甘改,死亡現(xiàn)場(chǎng)離奇詭異旅东,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)十艾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)抵代,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人忘嫉,你說(shuō)我怎么就攤上這事荤牍。” “怎么了庆冕?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵康吵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我访递,道長(zhǎng)晦嵌,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任拷姿,我火速辦了婚禮惭载,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘响巢。我一直安慰自己描滔,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布抵乓。 她就那樣靜靜地躺著伴挚,像睡著了一般。 火紅的嫁衣襯著肌膚如雪灾炭。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,365評(píng)論 1 302
  • 那天颅眶,我揣著相機(jī)與錄音蜈出,去河邊找鬼。 笑死涛酗,一個(gè)胖子當(dāng)著我的面吹牛铡原,可吹牛的內(nèi)容都是我干的偷厦。 我是一名探鬼主播,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼燕刻,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼只泼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起卵洗,我...
    開(kāi)封第一講書(shū)人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤请唱,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后过蹂,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體十绑,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年酷勺,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了本橙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡脆诉,死狀恐怖甚亭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情击胜,我是刑警寧澤亏狰,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站潜的,受9級(jí)特大地震影響骚揍,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜啰挪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一信不、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧亡呵,春花似錦抽活、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至汁胆,卻和暖如春梭姓,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背嫩码。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工誉尖, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人铸题。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓铡恕,卻偏偏與公主長(zhǎng)得像琢感,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子探熔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容