LeetCode206-反转链表

题目

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

代码

java 复制代码
/**
 * 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; }
 * }im 
 */
class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode cur = head;
        ListNode pre = null;
        while(cur != null) {
            ListNode next = cur.next;
            cur.next = pre;
            pre = cur;
            cur = next;
        }
        return pre;
    }
}

结论

  • 虚拟出一个pre节点很关键
  • 注意停止条件
  • 注意交换引用的逻辑
相关推荐
前进的李工2 小时前
LeetCode hot100:094 二叉树的中序遍历:从递归到迭代的完整指南
python·算法·leetcode·链表·二叉树
兩尛4 小时前
215. 数组中的第K个最大元素
数据结构·算法·排序算法
952364 小时前
数据结构-堆
java·数据结构·学习·算法
不会编程的小寒4 小时前
数据结构 2.0
数据结构·算法
while(1){yan}4 小时前
MYSQL索引的底层数据结构
数据结构·数据库·mysql
Wenhao.4 小时前
LeetCode Hot100 每日温度
数据结构·算法·leetcode·golang
CodeAmaz4 小时前
通用 List 分批切割并循环查询数据库工具类
java·数据结构·工具类·分页
xlq223225 小时前
15.list(上)
数据结构·c++·list
我不会插花弄玉5 小时前
排序【由浅入深-数据结构】
c语言·数据结构
XH华6 小时前
数据结构第三章:单链表的学习
数据结构