91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決反轉鏈表問題

發布時間:2021-10-14 13:41:53 來源:億速云 閱讀:167 作者:iii 欄目:編程語言

本篇內容主要講解“如何解決反轉鏈表問題”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何解決反轉鏈表問題”吧!

問題描述

給你單鏈表的頭指針 head 和兩個整數 left 和 right ,其中 left <= right 。請你反轉從位置 left 到位置 right 的鏈表節點,返回 反轉后的鏈表 。

示例 1:

輸入:head = [1,2,3,4,5], left = 2, right = 4

輸出:[1,4,3,2,5]

如何解決反轉鏈表問題

示例 2:

輸入:head = [5], left = 1, right = 1

輸出:[5]

解決方案

首先創建一個空節點指向head,兩個指針同時遍歷,并用tmp記錄當前節點的下一個節點用兩個指針遍歷整個鏈表,首先找到left的位置,當當前節點小于target時繼續讓當前節點指向下一個節點,直到找到left的位置,找到left的位置時便可使用頭插法將left后面的元素直到right插入到left前面

以示例1為例子:

1.初始狀態

如何解決反轉鏈表問題

2.第一輪變換

如何解決反轉鏈表問題

如何解決反轉鏈表問題


3.第三輪變換

如何解決反轉鏈表問題

如何解決反轉鏈表問題

代碼清單

 

 p1=ListNode(0)#創建空節點

        x=p1

        p1.next=head

        p=head#定義當前節點

        i=1#用于判斷與left的關系

        while i <left:#當沒有找到left時,繼續指向下一個節點

            p1=p1.next

            p=p.next

            i=i+1

        while i < right:#找到left時用頭插法進行插入

            tmp=p.next#記錄當前節點的下一個節點

            p.next=tmp.next

            tmp.next=p1.next

            p1.next=tmp

            i=i+1

        print( x.next)

 


到此,相信大家對“如何解決反轉鏈表問題”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

分宜县| 栾城县| 安宁市| 兴海县| 清镇市| 东兰县| 襄汾县| 马尔康县| 汨罗市| 安化县| 图木舒克市| 九台市| 衡南县| 宝鸡市| 正定县| 卢龙县| 鄂伦春自治旗| 隆昌县| 洪雅县| 眉山市| 阳朔县| 贡山| 抚宁县| 和顺县| 涿鹿县| 涿州市| 澄城县| 平江县| 曲阳县| 科尔| 惠东县| 广饶县| 巴楚县| 论坛| 韶关市| 临沭县| 呼和浩特市| 华宁县| 海安县| 凯里市| 房山区|