LeetCode----Linked List
Swap Nodes in Pairs
思路:需要构造一个头指针,指向链表。一次比较两个指针,将其翻转,临界条件是pre != null(链表长度为偶数) && pre.next != null(链表长度为奇数),然后更新头指针和pre
public ListNode swapPairs(ListNode head) {
if(head == null) return null;
ListNode newNode = new ListNode(0);
ListNode node = newNode;
node.next = head;
ListNode ptr = head;
while(ptr != null && ptr.next != null){
node.next = ptr.next;
ptr.next = ptr.next.next;
node.next.next = ptr;
node = node.next.next;
ptr = ptr.next;
}
return newNode.next;
}
Insertion Sort List
思路:构造一个头指针node,指向结果链表。每次取出head和结果链表中的节点val进行比较,知道找到应该插入的位置,插入,然后重置node和head
public ListNode insertionSortList(ListNode head) {
if(head == null) return null;
ListNode node = new ListNode(0);
while(head != null){
ListNode pre = node;
while(pre.next != null && pre.next.val <= head.val){
pre = pre.next;
}
ListNode temp = head.next;
head.next = pre.next;
pre.next = head;
head = temp;
}
return node.next;
}
Odd Even Linked List
思路:依次取出奇数位节点和偶数位节点,然后将奇数尾和偶数头连接起来
public ListNode oddEvenList(ListNode head) {
if(head == null || head.next == null) return head;
ListNode odd = head;
ListNode even = head.next;
ListNode temp = even;
while(even != null && even.next != null){
odd.next = even.next;
odd = odd.next;
even.next = odd.next;
even = even.next;
}
odd.next = temp;
return head;
}
Remove Duplicates from Sorted List II
思路:构造一个头结点指向链表,后面利用双指针判断val是否一致,若不一致则三个指针同时后移,若一直则尾指针后移直到不一致,利用头指针跳过所有重复的节点。
public ListNode deleteDuplicates(ListNode head) {
if(head == null || head.next == null) return head;
ListNode ptr = new ListNode(0);
ptr.next = head;
ListNode copy = ptr;
ListNode pre = head;
ListNode pos = head.next;
while(pos != null){
if(pos.val != pre.val){
ptr = ptr.next;
pre = pre.next;
pos = pos.next;
}
else{
while(pos != null && pos.val == pre.val){
pos = pos.next;
}
ptr.next = pos;
if(pos != null){
pre = pos;
pos = pos.next;
}
}
}
//ptr.next = null;
return copy.next;
}
Merge k Sorted Lists
思路:利用归并的思想,依次将链表的列表从中间分开,然后依次合并两个已排好序的链表
public ListNode mergeKLists(ListNode[] lists) {
int len = lists.length;
if(len == 0) return null;
return helper(lists,0,len - 1);
}
public ListNode helper(ListNode[] lists,int l,int r){
if(l < r){
int m = l + (r - l) / 2;
return merge(helper(lists,l,m),helper(lists,m + 1,r));
}
return lists[l];
}
public ListNode merge(ListNode l1,ListNode l2){
if(l1 == null) return l2;
if(l2 == null) return l1;
if(l1.val < l2.val){
l1.next = merge(l1.next,l2);
return l1;
}
else{
l2.next = merge(l1,l2.next);
return l2;
}
}
类似的:Sort List,也是归并的思想
Reverse Nodes in k-Group
思路:构造一个头指针指向链表,依次往后当长度等于k时,则翻转链表,这个过程注意需要保存要翻转链表的头结点
public ListNode reverseKGroup(ListNode head, int k) {
ListNode ptr = new ListNode(0);
ptr.next = head;
ListNode ptr1 = ptr;
ListNode curNode = head;
int cnt = 0;
while(curNode != null){
ListNode left = head;
cnt++;
if(cnt == k){
ListNode tail = curNode.next;
curNode.next = null;
ListNode leftCopy = left;
reverse(ptr1,left,curNode);
leftCopy.next = tail;
curNode = tail;
head = curNode;
ptr1 = leftCopy;
cnt = 0;
continue;
}
curNode = curNode.next;
}
return ptr.next;
}
public void reverse(ListNode ptr1,ListNode left,ListNode right){
ListNode p = null;
ListNode q = left;
while(left != right){
left = left.next;
q.next = p;
p = q;
q = left;
}
left.next = p;
ptr1.next = left;
}
141 双指针,一个快,一个慢,若过程中两指针相同则有环
19/61 双指针,相隔n
21 递归
160 得到两个链表的长度,重置长链表起点使之和短链表一致直到同时达到连接点
83/203 双指针
206 翻转指针
92 找到要翻转指针的范围,翻转
2/445 首先判断两链表长度,将长的那个作为被加数,即最终一定是加数先置为null,然后一位位相加,注意进位,然后判断是否多余的位上val都是9的情况,最后判断是否需要增加尾指针的情况;445比2多了一个翻转操作
86 构造两个头结点,分别表示不小于x的链表和小于x的链表,依次构造完以后拼接起来
常用的小模块和方法:
- 翻转链表
- 快慢指针得到链表中点
- 构造一个节点指向头结点
练习:
Palindrome Linked List:找到中点、翻转指针、依次比较
Delete Node in a Linked List:只能从要删除节点入手,则依次用后节点的val覆盖前节点的val
Reorder List:找到中点、翻转指针、依次连接
Linked List Cycle II:快慢指针找到相遇的位置,然后一个从head位置走,一个从相遇位置走,在环节点处相遇(注意没环的情况)
Convert Sorted List to Binary Search Tree:快慢指针找中点即头结点,递归建树
链表需注意:判头判尾是否为空、写到.next .val判断当前指针是否为空
LeetCode----Linked List的更多相关文章
- LeetCode Linked List Cycle II 和I 通用算法和优化算法
Linked List Cycle II Given a linked list, return the node where the cycle begins. If there is no cyc ...
- LeetCode & linked list bug
LeetCode & linked list bug add-two-numbers shit test /** * Definition for singly-linked list. * ...
- [LeetCode] Linked List Random Node 链表随机节点
Given a singly linked list, return a random node's value from the linked list. Each node must have t ...
- [LeetCode] Linked List Cycle II 单链表中的环之二
Given a linked list, return the node where the cycle begins. If there is no cycle, return null. Foll ...
- [LeetCode] Linked List Cycle 单链表中的环
Given a linked list, determine if it has a cycle in it. Follow up: Can you solve it without using ex ...
- [LeetCode]Linked List Cycle II解法学习
问题描述如下: Given a linked list, return the node where the cycle begins. If there is no cycle, return nu ...
- LeetCode——Linked List Cycle
Given a linked list, determine if it has a cycle in it. Follow up: Can you solve it without using ex ...
- LeetCode——Linked List Cycle II
Given a linked list, return the node where the cycle begins. If there is no cycle, return null. Foll ...
- [LeetCode] Linked List Components 链表组件
We are given head, the head node of a linked list containing unique integer values. We are also give ...
- [算法][LeetCode]Linked List Cycle & Linked List Cycle II——单链表中的环
题目要求 Linked List Cycle Given a linked list, determine if it has a cycle in it. Follow up: Can you so ...
随机推荐
- PCB Layout高速电路设计小知识点
1.单位:1mil = 0.0254mm 2.default线宽及线距(综合考虑高速电路性能及PCB板厂制程能力):6mil 3.差分走线特征阻抗:100ohm 4.3W原则,即线间距采用3倍线宽,多 ...
- Centos配置国内yum源
网易(163)yum源是国内最好的yum源之一 ,无论是速度还是软件版本,都非常的不错,将yum源设置为163yum,可以提升软件包安装和更新的速度,同时避免一些常见软件版本无法找到.具体设置方法如下 ...
- MySQL数据库9 - 日期与时间函数
一 日期和时间函数 函数的概念:按指定格式输入参数,返回正确结果的运算单元 1. 返回当前日期:curdate() current_date() current_date()+0可以将当前日期转换为数 ...
- 从UWP到SWIFT - TableBarController 和 Pivot
现在我还不是特别能适应swift中页面做bar的做法,感觉很奇怪. 现在我正在做一个简单的新浪微博,有一个主页,顶部有导航栏,底部是选项卡. 如果用wup来做的话,顶部应该是我们自己写的Usercon ...
- 中秋时候做了一个ppt画图插件
http://office.guanexcel.com/chart/chart.html PowerPoint里面简单的画图工具,输入数据选择图样即可插入到PPT中了
- ORACLE存储过程学习
存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR REPLACE PROCEDURE ...
- CentOS下查看进程和删除进程
1. 在 LINUX 命令平台输入 1-2 个字符后按 Tab 键会自动补全后面的部分(前提是要有这个东西,例如在装了 tomcat 的前提下, 输入 tomcat 的 to 按 tab).2. ps ...
- spring.net 如何让xml智能提示
tools ->options ->Text Editor ->xml ->miscellaneous ->network ->勾选 automatically d ...
- Javascript之Prototype
1.原型设计模式 在.Net中可以使用clone()来实现原型法 原型法的主要思想是,现在有1个类A,我想要创建一个类B,这个类是以A为原型的,并且能进行扩展.我们称B的原型为A. 2.javascr ...
- C#面向接口编程详解(1)——思想基础
我想,对于各位使用面向对象编程语言的程序员来说,“接口”这个名词一定不陌生,但是不知各位有没有这样的疑惑:接口有什么用途?它和抽象类有什么区别?能不能用抽象类代替接口呢?而且,作为程序员,一定经常听到 ...