LeetCode 206. 反转链表(迭代,双指针,Java)
Posted Kapo1
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 206. 反转链表(迭代,双指针,Java)相关的知识,希望对你有一定的参考价值。
与剑指 Offer 24. 反转链表一致
可以顺便复习头插法和尾插法的使用
题目
给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
示例 1:
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]
示例 2:
输入:head = [1,2]
输出:[2,1]
示例 3:
输入:head = []
输出:[]
提示:
链表中节点的数目范围是 [0, 5000]
-5000 <= Node.val <= 5000
进阶:链表可以选用迭代或递归方式完成反转。你能否用两种方法解决这道题?
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/reverse-linked-list
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
注意的地方
- 迭代,双指针
题解
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode() {}
* ListNode(int val) { this.val = val; }
* ListNode(int val, ListNode next) { this.val = val; this.next = next; }
* }
*/
class Solution {
public ListNode reverseList(ListNode head) {
ListNode p = null;
while(head != null) {
ListNode t = head.next;
head.next = p;
p = head;
head = t;
}
return p;
}
}
以上是关于LeetCode 206. 反转链表(迭代,双指针,Java)的主要内容,如果未能解决你的问题,请参考以下文章