日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java 链表反转_剑指BAT:如何最优雅着反转单链表?

發(fā)布時(shí)間:2024/9/19 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java 链表反转_剑指BAT:如何最优雅着反转单链表? 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

前言

以專題的形式更新刷題貼,歡迎跟我一起學(xué)習(xí)刷題,相信我,你的堅(jiān)持,絕對(duì)會(huì)有意想不到的收獲。每道題會(huì)提供簡(jiǎn)單的解答,如果你有更優(yōu)雅的做法,歡迎提供指點(diǎn),謝謝

【題目描述】

反轉(zhuǎn)單鏈表。例如鏈表為:

1->2->3->4

反轉(zhuǎn)后為

4->3->2->1

【要求】

如果鏈表的長度為 N, 時(shí)間復(fù)雜度達(dá)到 O(N), 額外空間復(fù)雜度達(dá)到 O(1)

【難度】

士:★☆☆☆

【解答】

方法1

這道題還是挺簡(jiǎn)單的,當(dāng)我們?cè)诜崔D(zhuǎn)一個(gè)節(jié)點(diǎn)的時(shí)候,把一個(gè)節(jié)點(diǎn)的后驅(qū)改為指向它前驅(qū)就可以了。這里需要注意的點(diǎn)就是,當(dāng)你把當(dāng)前節(jié)點(diǎn)的后驅(qū)指向前驅(qū)的時(shí)候,這個(gè)時(shí)候鏈表會(huì)被截?cái)?#xff0c;也就是說后面的節(jié)點(diǎn)和當(dāng)前節(jié)點(diǎn)分開了,所以我們需要一個(gè)變量來保存當(dāng)前節(jié)點(diǎn)的后驅(qū),以訪丟失。

具體代碼如下:

代碼如下

方法二

這道題也可以用遞歸來做,假設(shè) 方法 reverse() 的功能是將單鏈表進(jìn)行逆轉(zhuǎn)。采用遞歸的方法時(shí),我們可以不斷著對(duì)子鏈表進(jìn)行遞歸。例如對(duì)于如下的鏈表:

我們對(duì)子鏈表 2->3->4 進(jìn)行遞歸,即

Node newList = reverse(head.next)。遞歸之后的結(jié)果如下:

逆轉(zhuǎn)之后子鏈表 2->3->變?yōu)榱?4->3->2。

注意,我剛才假設(shè) reverse() 的功能就是對(duì)鏈表進(jìn)行逆轉(zhuǎn)。不過此時(shí)節(jié)點(diǎn) 1 仍然是指向節(jié)點(diǎn) 2 的。這個(gè)時(shí)候,我們?cè)侔压?jié)點(diǎn)1 和 2逆轉(zhuǎn)一下,然后 1 的下一個(gè)節(jié)點(diǎn)指向 null 就可以了。如圖:

遞歸的結(jié)束條件就是:當(dāng)子鏈表只有一個(gè)節(jié)點(diǎn),或者為 null 時(shí),遞歸結(jié)束。代碼如下:

問題拓展

題目:反轉(zhuǎn)部分鏈表節(jié)點(diǎn)

【題目描述】

題目:給定一個(gè)單向鏈表的頭結(jié)點(diǎn)head,以及兩個(gè)整數(shù)from和to ,在單項(xiàng)鏈表上把第from個(gè)節(jié)點(diǎn)和第to個(gè)節(jié)點(diǎn)這一部分進(jìn)行反轉(zhuǎn)

列如:

1->2->3->4->5->null,from=2,to=4

結(jié)果:1->4->3->2->5->null

列如:

1->2->3->null from=1,to=3

結(jié)果為3->2->1->null

【要求】

1、如果鏈表長度為N,時(shí)間復(fù)雜度要求為O(N),額外空間復(fù)雜度要求為O(1)

2、如果不滿足1<=from<=to<=N,則不調(diào)整

【難度】

士:★☆☆☆

【解答】

每日推送原創(chuàng)文章,專注于寫數(shù)據(jù)結(jié)構(gòu)與算法,輔寫計(jì)算機(jī)網(wǎng)絡(luò)、計(jì)算機(jī)基礎(chǔ)、Java,期待各位的關(guān)注,保證讓你有所收獲。不信你試試

總結(jié)

以上是生活随笔為你收集整理的java 链表反转_剑指BAT:如何最优雅着反转单链表?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。