LeetCode_61 旋轉(zhuǎn)鏈表(鏈表題)

題目地址:https://leetcode-cn.com/problems/rotate-list/

題目:

給定一個(gè)鏈表,旋轉(zhuǎn)鏈表萎庭,將鏈表每個(gè)節(jié)點(diǎn)向右移動 k 個(gè)位置趴俘,其中 k 是非負(fù)數(shù)忌傻。

示例 1:

輸入: 1->2->3->4->5->NULL, k = 2
輸出: 4->5->1->2->3->NULL
解釋:
向右旋轉(zhuǎn) 1 步: 5->1->2->3->4->NULL
向右旋轉(zhuǎn) 2 步: 4->5->1->2->3->NULL

試題分析:

這道題如果前期沒有準(zhǔn)備過直接寫很容易漏掉一些異常處理和移位超出鏈表長度的處理屁置,總體算法思路是先找到需要旋轉(zhuǎn)的位置,這里有一個(gè)點(diǎn)需要注意下朗若,就是移動的位數(shù)k有可能會大于鏈表總長度恼五,所以需要先遍歷出鏈表總長度,然后總長度減去k后按照總長度取模 length-k%length 遍歷鏈表找到要旋轉(zhuǎn)的節(jié)點(diǎn)位置哭懈,然后定義一個(gè)旋轉(zhuǎn)后的鏈表頭指向這個(gè)節(jié)點(diǎn)的next灾馒,然后讓舊鏈表的尾節(jié)點(diǎn)和舊鏈表的頭節(jié)點(diǎn)對接,這樣就完成了旋轉(zhuǎn)遣总。

代碼:

public ListNode rotateRight(ListNode head, int k) {
        if(head==null || k==0 ||head.next==null){
            return head;
        }
        ListNode p = head;
        //遍歷出鏈表長度
        int length = 0;
        ListNode tail = head;
        for(;tail.next!=null;tail=tail.next){
            length++;
        }
        length++;

        //找到需要反轉(zhuǎn)的節(jié)點(diǎn)的前置節(jié)點(diǎn)
        for(int i=1;i<length-k%length;i++){
            p = p.next;
        }
        //如果反轉(zhuǎn)節(jié)點(diǎn)的前置節(jié)點(diǎn)是最后一個(gè)節(jié)點(diǎn)則不需要反轉(zhuǎn)直接返回原頭節(jié)點(diǎn)
        if(p.next==null){
            return head;
        }else {
            //新翻轉(zhuǎn)后的頭節(jié)點(diǎn)指向剛才遍歷出的反轉(zhuǎn)節(jié)點(diǎn)的前置節(jié)點(diǎn)的next節(jié)點(diǎn)
            ListNode newHead = p.next;
            //尾節(jié)點(diǎn)next指向原h(huán)ead節(jié)點(diǎn)
            tail.next = head;
            p.next = null;
            return newHead;
        }
    }

源碼路徑:com.monkey01.linkedlist.RotateList_61

配套測試代碼路徑:test目錄com.monkey01.linkedlist.RotateList_61Test

https://github.com/feiweiwei/LeetCode4Java.git

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末睬罗,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子旭斥,更是在濱河造成了極大的恐慌容达,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件垂券,死亡現(xiàn)場離奇詭異花盐,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)圆米,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進(jìn)店門卒暂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來啄栓,“玉大人娄帖,你說我怎么就攤上這事£汲” “怎么了近速?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長堪旧。 經(jīng)常有香客問我削葱,道長,這世上最難降的妖魔是什么淳梦? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任析砸,我火速辦了婚禮,結(jié)果婚禮上爆袍,老公的妹妹穿的比我還像新娘首繁。我一直安慰自己作郭,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布弦疮。 她就那樣靜靜地躺著夹攒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪胁塞。 梳的紋絲不亂的頭發(fā)上咏尝,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機(jī)與錄音啸罢,去河邊找鬼编检。 笑死,一個(gè)胖子當(dāng)著我的面吹牛扰才,可吹牛的內(nèi)容都是我干的蒙谓。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼训桶,長吁一口氣:“原來是場噩夢啊……” “哼累驮!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起舵揭,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤谤专,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后午绳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體置侍,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年拦焚,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蜡坊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,090評論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赎败,死狀恐怖秕衙,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情僵刮,我是刑警寧澤据忘,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站搞糕,受9級特大地震影響勇吊,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜窍仰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一汉规、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧驹吮,春花似錦针史、人聲如沸膏燕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽坝辫。三九已至,卻和暖如春射亏,著一層夾襖步出監(jiān)牢的瞬間近忙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工智润, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留及舍,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓窟绷,卻偏偏與公主長得像锯玛,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子兼蜈,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評論 2 355

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

  • 搞懂單鏈表常見面試題 Hello 繼上次的 搞懂基本排序算法攘残,這個(gè)一星期,我總結(jié)了为狸,我所學(xué)習(xí)和思考的單鏈表基礎(chǔ)知識...
    醒著的碼者閱讀 4,588評論 1 45
  • 本文首發(fā)于我的個(gè)人博客:尾尾部落 鏈表是面試過程中經(jīng)常被問到的辐棒,這里把劍指offer 和 LeetCode 中的相...
    繁著閱讀 2,143評論 1 15
  • 動態(tài)規(guī)劃 111. 爬樓梯思路類似斐波那契數(shù)列注意考慮第 0 階的特殊情況 272. 爬樓梯 II思路類似上題病曾,只...
    6默默Welsh閱讀 2,431評論 0 1
  • 作為創(chuàng)業(yè)者泰涂,會經(jīng)歷幸福,更會經(jīng)歷無數(shù)的困難辐怕,磨練讓我深刻體悟到:戰(zhàn)略上要非常感性逼蒙,戰(zhàn)術(shù)上要足夠理性。 戰(zhàn)略上秘蛇,認(rèn)準(zhǔn)...
    倉叔日記閱讀 473評論 0 0
  • 當(dāng)金牛愛上獅子 當(dāng)獅子愛上金牛 55牧慕 如今其做,每當(dāng)下大雪的時(shí)候,我就會不由自主的想起那個(gè)大雪壓境的夜晚赁还,我抽了一...
    草原上的咩咩羊閱讀 153評論 0 0