真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java如何實(shí)現(xiàn)對(duì)鏈表進(jìn)行插入排序

這篇文章主要介紹java如何實(shí)現(xiàn)對(duì)鏈表進(jìn)行插入排序,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

目前創(chuàng)新互聯(lián)已為1000多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬空間、網(wǎng)站運(yùn)營、企業(yè)網(wǎng)站設(shè)計(jì)、松桃網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

對(duì)鏈表進(jìn)行插入排序。

java如何實(shí)現(xiàn)對(duì)鏈表進(jìn)行插入排序

插入排序的動(dòng)畫演示如上。從第一個(gè)元素開始,該鏈表可以被認(rèn)為已經(jīng)部分排序(用黑色表示)。

每次迭代時(shí),從輸入數(shù)據(jù)中移除一個(gè)元素(用紅色表示),并原地將其插入到已排好序的鏈表中。

插入排序算法:

  1. 插入排序是迭代的,每次只移動(dòng)一個(gè)元素,直到所有元素可以形成一個(gè)有序的輸出列表。

  2. 每次迭代中,插入排序只從輸入數(shù)據(jù)中移除一個(gè)待排序的元素,找到它在序列中適當(dāng)?shù)奈恢?,并將其插入?/p>

  3. 重復(fù)直到所有輸入數(shù)據(jù)插入完為止。

示例 1:

輸入: 4->2->1->3
輸出: 1->2->3->4

示例 2:

輸入: -1->5->3->4->0
輸出: -1->0->3->4->5

答案:

 1public ListNode insertionSortList(ListNode head) {
2    if (head == null)
3        return head;
4    ListNode helper = new ListNode(0);
5    ListNode cur = head;
6    ListNode pre = helper;
7    ListNode next = null;
8    while (cur != null) {
9        next = cur.next;
10        while (pre.next != null && pre.next.val < cur.val) {
11            pre = pre.next;
12        }
13        cur.next = pre.next;
14        pre.next = cur;
15        pre = helper;
16        cur = next;
17    }
18    return helper.next;
19}

解析:

關(guān)于排序前面我們介紹了十幾種排序算法,這里讓使用插入排序,其實(shí)插入排序并不難,這里難的是鏈表的斷開和重連。當(dāng)然我們還可以使用其他的方法,比如我們把鏈表的每一個(gè)節(jié)點(diǎn)全部斷開,然后存放到數(shù)組中,接著在排序,最后再把排序好的數(shù)組按順序全部再連接起來即可。

以上是“java如何實(shí)現(xiàn)對(duì)鏈表進(jìn)行插入排序”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


文章題目:java如何實(shí)現(xiàn)對(duì)鏈表進(jìn)行插入排序
轉(zhuǎn)載源于:http://weahome.cn/article/jgsggh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部