選擇排序、冒泡排序胧卤、插入排序代碼實(shí)現(xiàn)

排序概念和思路已在注釋中寫明唯绍,此處不贅述。

package sort;

/**
 * @Author Seth
 * @Date 2021/9/7
 */
public class Sort {
    public static void main(String[] args) {
        int[] arr = {2,1,6,7,4,8,0};
        SortUtil.printArr(arr);
        insertionSort(arr);
        SortUtil.printArr(arr);
    }

    /**
     * 插入排序
     * 給定一個(gè)數(shù)組arr,長(zhǎng)度為N(N > 2),整體思路是先保證
     * 索引0~索引0位置有序枝誊、
     * 索引0~索引1位置有序况芒、
     * 索引0~索引2位置有序、
     * 索引0~索引3位置有序叶撒、
     * ...
     * 索引0~索引N-1位置有序
     *
     * 操作步驟:
     * 1绝骚、保證索引0~索引0位置有序,相同位置一定有序祠够,不需要操作
     * 2压汪、索引0~索引1位置有序,比較arr[0],arr[1],如果arr[1] < arr[0]古瓤,交換arr[0]和arr[1]的位置止剖;
     * 3腺阳、索引0~索引2位置有序,比較arr[1],arr[2],如果arr[2] < arr[1]穿香,交換arr[1]和arr[2]的位置亭引;比較arr[0],arr[1],如果arr[1] < arr[0],交換arr[0]和arr[1]的位置皮获;
     * 4焙蚓、索引0~索引3位置有序,比較arr[2],arr[3],如果arr[3] < arr[2]洒宝,交換arr[2]和arr[3]的位置主届;比較arr[1],arr[2],如果arr[2] < arr[1],交換arr[1]和arr[2]的位置待德;比較arr[0],arr[1],如果arr[1] < arr[0]君丁,交換arr[0]和arr[1]的位置;
     * ...
     * N将宪、索引0~索引N-1位置有序绘闷,比較arr[N-2],arr[N-1],如果arr[N-1] < arr[N-2],交換arr[N-1]和arr[N-2]的位置较坛;比較arr[N-3],arr[N-2],如果arr[N-2] < arr[N-3]印蔗,交換arr[N-2]和arr[N-3]的位置.....比較arr[0],arr[1],如果arr[1] < arr[0],交換arr[0]和arr[1]的位置丑勤;
     *
     * @param arr 待排序數(shù)組
     */
    public static void insertionSort(int[] arr){
        // 先處理邊界
        if (arr == null || arr.length < 2) {
            return;
        }

        int N = arr.length;

        for (int i = 0; i < N; i++) {
            for (int j = i; j - 1 >= 0 && arr[j] < arr[j-1]; j--) {
                SortUtil.swap(arr, j, j - 1);
            }
        }
    }


    /**
     * 冒泡排序
     * 倒一杯水在玻璃杯里华嘹,我們都看見過,杯中的水會(huì)有泡泡向上浮起法竞。冒泡排序的過程跟這個(gè)過程相似耙厚,
     * 給定一個(gè)數(shù)組arr,相鄰索引之間兩兩比較岔霸,將更大的數(shù)字向后移動(dòng)薛躬,這樣第一次比較之后數(shù)組長(zhǎng)度N-1的位置一定是最大的數(shù)字;
     * 再兩兩比較呆细,到數(shù)組N-2的位置型宝,這樣N-2一定是第二大的數(shù)字,重復(fù)這個(gè)步驟即可完成冒泡排序絮爷。
     *
     * 操作步驟:
     * 1. 比較索引0趴酣,1位置的數(shù)字,如果arr[0]>arr[1},交換arr[0]和arr[1]的位置,否則不交換位置坑夯;比較索引1,2位置的數(shù)字岖寞,如果arr[1]>arr[2],交換arr[1]和arr[2]渊涝,否則不交換位置慎璧;比較arr[N-2]和arr[N-1]...
     * 2. 比較索引0床嫌,1位置的數(shù)字跨释,如果arr[0]>arr[1},交換arr[0]和arr[1]的位置,否則不交換位置胸私;比較索引1,2位置的數(shù)字,如果arr[1]>arr[2]鳖谈,交換arr[1]和arr[2]岁疼,否則不交換位置;比較arr[N-3]和arr[N-2]...
     * 3. 比較索引0缆娃,1位置的數(shù)字捷绒,如果arr[0]>arr[1},交換arr[0]和arr[1]的位置,否則不交換位置;比較索引1,2位置的數(shù)字贯要,如果arr[1]>arr[2]暖侨,交換arr[1]和arr[2],否則不交換位置崇渗;比較arr[N-4]和arr[N-3]...
     *
     * @param arr 待排序數(shù)組
     */
    public static void bubbleSort(int[] arr) {
        // 先處理邊界
        if (arr == null || arr.length <2) {
            return;
        }

        int N = arr.length;
        for (int i = 0; i < N; i++) {
            for (int j = 0; j < N - i - 1; j++) {
                if (arr[j] > arr[j + 1]) {
                    SortUtil.swap(arr, j, j + 1);
                }
            }
        }
    }

    /**
     * 選擇排序
     * 給定一個(gè)數(shù)組字逗,使用選擇排序時(shí),先假定第一個(gè)位置是最小值宅广,依次向后查找葫掉,找到更小的數(shù)就更新最小索引,遍歷完成交換第一個(gè)位置和最小索引數(shù)跟狱;再假定第二個(gè)位置是最小值俭厚,
     * 依次向后查找,找到更小的數(shù)就更新最小索引驶臊,遍歷完成交換第二個(gè)位置和最小索引數(shù);重復(fù)這個(gè)步驟挪挤,最后假定數(shù)組長(zhǎng)度N-2的位置是最小值,與N-1的位置比較关翎,如果后面的數(shù)更小
     * 就交換位置电禀。這樣整個(gè)數(shù)組就排序完成了。
     *
     * 操作步驟:
     * 1笤休、假定最小數(shù)索引minValueIndex = 0,依次比較索引1,2,3...N, 如果找到更小的數(shù)尖飞,更新最小索引minValueIndex,交換索引0和minValueIndex的數(shù)字
     * 2店雅、假定最小數(shù)索引minValueIndex = 1,依次比較索引2,3...N, 如果找到更小的數(shù)政基,更新最小索引minValueIndex,交換索引1和minValueIndex的數(shù)字
     * 3闹啦、假定最小數(shù)索引minValueIndex = 2,依次比較索引2,3...N, 如果找到更小的數(shù)沮明,更新最小索引minValueIndex,交換索引2和minValueIndex的數(shù)字
     * .
     * .
     * .
     * N、假定最小數(shù)索引minValueIndex = N-1,依次比較索引N-1,N, 如果找到更小的數(shù)窍奋,更新最小索引minValueIndex,交換索引N-1和minValueIndex的數(shù)字
     * @param arr 待排序數(shù)組
     */
    public static void selectionSort(int[] arr) {
        // 先處理邊界
        if (arr == null || arr.length < 2) {
            return;
        }

        int N = arr.length;
        for (int i = 0; i < N; i++) {
            int minValueIndex = i;
            for (int j = i + 1; j < N; j++) {
                if (arr[minValueIndex] > arr[j]) {
                    minValueIndex = j;
                }
            }
            SortUtil.swap(arr, i, minValueIndex);
        }

    }
}

SortUtil工具類

package sort;

/**
 * @Author Seth
 * @Date 2021/9/7
 */
public class SortUtil {
    /**
     * 打印數(shù)組
     * 
     * @param arr 數(shù)組
     */
    public static void printArr(int[] arr){
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println();
    }

    /**
     * 交換數(shù)組中索引為i, j的數(shù)字的位置
     * 
     * @param arr 數(shù)組
     * @param i 要交換位置的索引
     * @param j 要交換位置的索引
     */
    public static void swap(int[] arr, int i, int j) {
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末荐健,一起剝皮案震驚了整個(gè)濱河市酱畅,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌江场,老刑警劉巖纺酸,帶你破解...
    沈念sama閱讀 218,451評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異址否,居然都是意外死亡餐蔬,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門佑附,熙熙樓的掌柜王于貴愁眉苦臉地迎上來樊诺,“玉大人,你說我怎么就攤上這事音同〈逝溃” “怎么了?”我有些...
    開封第一講書人閱讀 164,782評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵权均,是天一觀的道長(zhǎng)顿膨。 經(jīng)常有香客問我,道長(zhǎng)螺句,這世上最難降的妖魔是什么虽惭? 我笑而不...
    開封第一講書人閱讀 58,709評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮蛇尚,結(jié)果婚禮上芽唇,老公的妹妹穿的比我還像新娘。我一直安慰自己取劫,他們只是感情好匆笤,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著谱邪,像睡著了一般炮捧。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上惦银,一...
    開封第一講書人閱讀 51,578評(píng)論 1 305
  • 那天咆课,我揣著相機(jī)與錄音,去河邊找鬼扯俱。 笑死书蚪,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的迅栅。 我是一名探鬼主播殊校,決...
    沈念sama閱讀 40,320評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼读存!你這毒婦竟也來了为流?” 一聲冷哼從身側(cè)響起呕屎,我...
    開封第一講書人閱讀 39,241評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎敬察,沒想到半個(gè)月后秀睛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,686評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡静汤,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評(píng)論 3 336
  • 正文 我和宋清朗相戀三年琅催,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了居凶。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片虫给。...
    茶點(diǎn)故事閱讀 39,992評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖侠碧,靈堂內(nèi)的尸體忽然破棺而出抹估,到底是詐尸還是另有隱情,我是刑警寧澤弄兜,帶...
    沈念sama閱讀 35,715評(píng)論 5 346
  • 正文 年R本政府宣布药蜻,位于F島的核電站,受9級(jí)特大地震影響替饿,放射性物質(zhì)發(fā)生泄漏语泽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評(píng)論 3 330
  • 文/蒙蒙 一视卢、第九天 我趴在偏房一處隱蔽的房頂上張望踱卵。 院中可真熱鬧,春花似錦据过、人聲如沸惋砂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)西饵。三九已至,卻和暖如春鳞芙,著一層夾襖步出監(jiān)牢的瞬間眷柔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工原朝, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留驯嘱,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,173評(píng)論 3 370
  • 正文 我出身青樓竿拆,卻偏偏與公主長(zhǎng)得像宙拉,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子丙笋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評(píng)論 2 355

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