栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

leetcode链表经典题目(python)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

leetcode链表经典题目(python)

leetcode题目链接

文章目录
  • 一、引入头节点作用
  • 二、设计链表
  • 三、206反转链表
  • 四、142环形链表


一、引入头节点作用

链表的一大问题就是操作当前节点必须要找前一个节点才能操作。这就造成了,头结点的尴尬,因为头结点没有前一个节点了。每次对应头结点的情况都要单独处理,所以使用虚拟头结点的技巧,就可以解决这个问题。
引入头节点主要作用是为了使操作一致,而不必单独考虑头节点

二、设计链表

707设计链表 考察了常见的五个操作。这里贴出我写的代码,把这几个掌握

#节点定义
class Node:
    def __init__(self,val):
        self.val=val
        self.next=None
#链表类
class MyLinkedList:

    def __init__(self):
        self._head=Node(0)#头节点
        self._count=0

    def get(self, index: int) -> int:
        if 0 <= index  None:
        self.addAtIndex(0,val)


    def addAtTail(self, val: int) -> None:
        self.addAtIndex(self._count,val)


    def addAtIndex(self, index: int, val: int) -> None:
        if index<0 :
            index=0
        elif index>self._count :
            return
        self._count+=1
        node=Node(val)
        pre=self._head
        for _ in range(index):
            pre=pre.next
        node.next=pre.next
        pre.next=node


    def deleteAtIndex(self, index: int) -> None:
        if index<0 or index>=self._count :
            return 
        self._count-=1
        pre=self._head
        for _ in range(index):
            pre=pre.next
        pre.next=pre.next.next
                



# Your MyLinkedList object will be instantiated and called as such:
# obj = MyLinkedList()
# param_1 = obj.get(index)
# obj.addAtHead(val)
# obj.addAtTail(val)
# obj.addAtIndex(index,val)
# obj.deleteAtIndex(index)


三、206反转链表

题目链接
其实只需要改变链表的next指针的指向,直接将链表反转 ,而不用重新定义一个新的链表,不断地把后面的指针指向前面。
双指针法

四、142环形链表

题目链接

  • 如何判断是否有环?
    快慢指针法,快指针每次走两步,慢指针每次走一步。如果有环的话,最后两个指针一定会相遇。因为在这里快指针就相当于一步一步的靠近慢指针
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/871021.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号