题目
给定单链表的头节点 head ,请反转链表,并返回反转后的链表的头节点。
输入: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/problems/UHnkqh
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
代码和思路
一、递归
1、使用递归
2、注意点:
- 1、结束条件
- 2、每次递归要干嘛
- 3、从哪里return,从哪个点开始递归
二、迭代
1、使用三个指针
2、注意点:
- 1、两个指针的目的主要是用于迭代
- 2、还一个指针主要目的是,存放下一个节点的位置,用于迭代
/**
* 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) {
// base case
if(head == null || head.next == null){
// System.out.println("val===="+head.val);
// 5直接return
return head;
}
// 一直递归到尾节点
ListNode last = reverseList(head.next);
// 递归从4开始
System.out.println(head.val);
head.next.next = head;
head.next = null;
return last;
}
}
// 方法二、迭代法,使用 三个指针方式
public ListNode reverseList(ListNode head) {
// 定义指针
ListNode cur = head;
ListNode pre = null;
// 开始迭代
while(cur != null){
// 使用临时指针保存节点
ListNode temp = cur.next;
// 交换指针位置
cur.next = pre;
// 指针后移
pre = cur;
cur =temp ;
}
return pre;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/96178.html