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

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

leetcode如何分隔鏈表

本篇內(nèi)容主要講解“l(fā)eetcode如何分隔鏈表”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“l(fā)eetcode如何分隔鏈表”吧!

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:主機(jī)域名、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、舟山網(wǎng)站維護(hù)、網(wǎng)站推廣。

一、題目內(nèi)容

給你一個鏈表和一個特定值 x ,請你對鏈表進(jìn)行分隔,使得所有小于 x 的節(jié)點(diǎn)都出現(xiàn)在大于或等于 x 的節(jié)點(diǎn)之前。

你應(yīng)當(dāng)保留兩個分區(qū)中每個節(jié)點(diǎn)的初始相對位置。

示例:

輸入:head = 1->4->3->2->5->2, x = 3
輸出:1->2->2->4->3->5

二、解題思路

創(chuàng)建兩個鏈表,一個存放小于x的,一個存放大于x的,順序不動,最后將兩個鏈表進(jìn)行拼接即可。

三、代碼

# Definition for singly-linked list.
class ListNode:
    def __init__(self, x):
        self.val = x
        self.next = None

    def __repr__(self):
        return str(self.val)

class Solution:
    def partition(self, head: ListNode, x: int) -> ListNode:
        if not head:
            return head
        head1 = ListNode(0)
        head2 = ListNode(0)
        cur1 = head1
        cur2 = head2
        while head:
            if head.val < x:
                cur1.next = head
                head = head.next
                cur1 = cur1.next
                cur1.next = None
            else:
                cur2.next = head
                head = head.next
                cur2 = cur2.next
                cur2.next = None
        cur1.next = head2.next
        return head1.next


if __name__ == '__main__':
    s = Solution()
    head_list = [1, 4, 3, 2, 5, 2]
    head = ListNode(head_list[0])
    cur = head
    for i in range(1, len(head_list)):
        cur.next = ListNode(head_list[i])
        cur = cur.next
    x = 3
    ans = s.partition(head, x)
    print(ans)

到此,相信大家對“l(fā)eetcode如何分隔鏈表”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


文章題目:leetcode如何分隔鏈表
網(wǎng)頁地址:http://weahome.cn/article/ppsjpg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部