LEETCODE - Linked List 题目思路汇总
时间:2022-05-06
本文章向大家介绍LEETCODE - Linked List 题目思路汇总,主要内容包括[1] 调换顺序、[2] 删除、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
浏览了一下 Leetcode 上 Linked List 的题目,我把它分为 6 类:
- 调换顺序
- 删除
- 合并
- 环
- 变身
- 复制
做Leetcode还是要归类总结才好玩,最开始做两三个觉得很懵,做四五个就能发现规律,找到适合自己的思考方式,剩下的题就都迎刃而解。打通任督二脉后,做题也会上瘾,练练脑子还挺好玩的。
每个题的源码和详细思路可以看这里。
目前做完:
- 调换顺序:234,147,206,24,143,328,61
- 删除:19,83,203,82
- 合并:21,160
- 环:141,142
- 变身:109,2
今天周六,是玩的时间,不过晚上回来还是做了几个题,其他题目如果感兴趣的话可以去上面的链接里看。
[1] 调换顺序
328,Odd Even Linked List
# Definition for singly-linked list.
# class ListNode(object):
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution(object):
def oddEvenList(self, head):
"""
:type head: ListNode
:rtype: ListNode
"""
if head is None:
return head
odd = oddHead = head
even = evenHead = head.next
while even and even.next:
odd.next = odd.next.next
even.next = even.next.next
odd = odd.next
even = even.next
odd.next = evenHead
return oddHead
61,Rotate List
# Definition for singly-linked list.
# class ListNode(object):
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution(object):
def rotateRight(self, head, k):
if head is None or head.next is None or k == 0:
return head
dummy = ListNode(0)
dummy.next = head
# 计算length,求余数,求step
p = dummy #p从dummy开始,步数就可以和length保持一致
length = 0
while p.next: #p最后是走到尾部,而不是None,这样可以连接指向原head
length += 1
p = p.next
# 计算长度的同时,顺便把尾部指向原head
p.next = head
# 找到新head
step = length - k % length
while step > 0: #p从尾部开始,相当于从dummy开始,步数和step保持一致
p = p.next
step -= 1
dummy.next = p.next
p.next = None
return dummy.next
[2] 删除
82,Remove Duplicates from Sorted List II
# Definition for singly-linked list.
# class ListNode(object):
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution(object):
def deleteDuplicates(self, head):
if head is None or head.next is None:
return head
dummy = ListNode(0)
dummy.next = head
last = dummy
cur = head
while cur and cur.next:
p = cur.next
if p.val != cur.val:
last.next = cur
last = cur
cur = p
else:
while p and p.val == cur.val:
p = p.next
cur = p
last.next = cur
return dummy.next
- C/C++对bool operator < (const p &a)const的认识,运算符重载详解(杂谈)
- C/C++中substr函数的应用(简单讲解)
- C++ STL学习之容器set和multiset (补充材料)
- Codeforces Round #410 (Div. 2)(A,字符串,水坑,B,暴力枚举,C,思维题,D,区间贪心)
- 关于int *a[常量]与int (*a)[常量]的分析与区分(详解)
- python笔记3-发送邮件(smtplib)
- 关关的刷题日记01—Leetcode 169. Majority Element
- 关小刷刷题02——Leetcode 169. Majority Element 方法2和3
- 树链剖分简单分析及模板(杂谈)
- 第十五届北京师范大学程序设计竞赛现场决赛题解&源码(A.思维,C,模拟,水,坑,E,几何,思维,K,字符串处理)
- python+requests接口自动化项目完整框架设计
- POJ 1804 Brainman(5种解法,好题,【暴力】,【归并排序】,【线段树单点更新】,【树状数组】,【平衡树】)
- 关关的刷题日记03—Leetcode 448. Find All Numbers Disappeared in an Array
- 关关的刷题日记04——Leetcode 283. Move Zeroes
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法