Python基础编程练习LeetCode——链表

Python基础编程练习LeetCode——链表

Python基础编程练习LeetCode——链表

题目来源:LeetCode:19,21,141,206,234

19、删除链表的倒数第N个节点

输入

给出一个链表: 1->2->3->4->5 和 n = 2.

输出

链表:1->2->3->5.

解题思路

解题思路:本题需要两个指针,pre和end。一开始初始化时使得pre指针指向链表头节点head,end指针指向pre+n的节点位置。同时往后移动pre和end指针位置,使得end指针指向最后一个节点,那么pre指针指向的则是end-n的节点位置(即倒数第n个元素的前一个节点),则将其删除。

完整代码

class Solution:
    def removeNthFromEnd(self, head: ListNode, n: int) -> ListNode:
        pre = head
        end = head
        for i in range(n):
            end = end.next
        if end is None:  
            return head.next
        while end.next is not None:
            pre = pre.next
            end = end.next
        pre.next = pre.next.next 
        return head

21、合并两个有序链表

输入

1->2->4, 1->3->4

输出

1->1->2->3->4->4

解题思路

解题思路:新建一个空链表,只要两个链表不为空,比较两个链表中当前值,小的放入L空链表中,并把指针后移,直到某一链表为空ÿ

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值