20天速通LeetCodeday09:关于链表

前言

今日练习目的:掌握如何遍历链表,以及改变节点的next指向。

206:反转链表

题目要求:给定一个单链表的头节点head

要求:反转链表,并返回反转后的链表

核心思路

使用三个指针:

prev:当前节点的前一个节点

cur :当前正在处理的节点

next:临时保存 cur 的下一个节点

代码实现

java 复制代码
class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode prev = null;
        ListNode cur = head;

        while (cur != null) {
            ListNode next = cur.next; // 保存下一个节点
            cur.next = prev;          // 反转指针
            prev = cur;               // prev 前进
            cur = next;               // cur 前进
        }

        return prev;
    }
}

总结

掌握链表的语法:listNode prev=null

203:移除链表元素

题目要求:给定一个链表头节点head和一个值val。

要求:删除链表中所有等于val的节点,并返回head

核心思路

引入虚拟头节点dummy,防止第一个元素就是需要被删除元素

遍历的逻辑:

如果 cur.next.val == val:

删除 cur.next

否则:

cur 向后移动

代码实现

java 复制代码
class Solution {
    public ListNode removeElements(ListNode head, int val) {
        // 虚拟头节点
        ListNode dummy = new ListNode(0);
        dummy.next = head;

        ListNode cur = dummy;

        while (cur.next != null) {
            if (cur.next.val == val) {
                cur.next = cur.next.next; // 删除节点
            } else {
                cur = cur.next; // 移动指针
            }
        }

        return dummy.next;
    }
}

总结

掌握虚拟头节点的创建:ListNode dummy=new ListNode(0); dummy.next=head

遍历的逻辑

返回dummy的语法:return dummy.next

21:合并两个有序链表

题目要求:给定两个升序排列的链表list1和list2

要求:将他们合并成一个新的升序链表并返回

核心思路

双指针+虚拟头节点

将两个链表取出元素进行比较并拼接

最后将剩余链表拼接

代码实现

java 复制代码
ListNode dummy=new ListNoed(0);
ListNode cur=dummy;

ListNode p1=list1;
ListNode p2=list2;

while(p1!=null&&p2!=null){
if(p1.val<p2.val){
cur=p1.val;
p1=p1.next;
}else{
cur=p2.next;
p2=p2.next;
}
cur=cur.next;
}
//拼接剩余
if(p1!=null){
cur=p1;
}else{
cur=p2;}
return dummy.next;

总结

要求做到升序链表,想到用双指针来判断头节点的大小

用剩余链表直接收尾

2:两数相加

题目要求:给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。

请你将两个数相加,并以相同形式返回一个表示和的链表。

你可以假设除了数字 0 之外,这两个数都不会以 0 开头

核心思路

代码实现

java 复制代码
ListNode dummy=new ListNode(0);
ListNode cur=dummy;

int carry=0;
while(l1!=null||l2!=null||carry!=0){
int sum=carry;
if(l1!=null){
sum+=l1.val;
l1.l1.next;
}
if(l2!=null){
sum+=l2.val;
l2=l2.next;
}
carry=sum/10;
cur.next=new ListNode(sum%10);
cur=cur.next;
}
return dummy.next;

总结

本题的核心是:链表逐位相加 + 进位 carry

核心三要素

  1. sum = l1 + l2 + carry
  1. 当前位 = sum % 10
  2. carry = sum / 10
相关推荐
pluviophile_s12 小时前
数据结构:第2讲:线性表
数据结构·笔记
Love_云宝儿16 小时前
WKT数据示例并与GeoJSON数据对比
数据结构·gis
风筝在晴天搁浅16 小时前
快手 CodeTop LeetCode 224.基本计算器
数据结构·算法·leetcode
牢姐与蒯16 小时前
c++数据结构之c++11(一)
数据结构·c++
iiiiyu17 小时前
IO流(二)
java·开发语言·数据结构·编程语言
啦啦啦啦啦zzzz17 小时前
数据结构:平衡二叉树
数据结构·c++·二叉树
Ameilide20 小时前
数据结构 树 二叉树
数据结构
WWW652620 小时前
代码随想录 打卡第四十七天
数据结构·算法·leetcode
cpp_250120 小时前
P10722 [GESP202406 六级] 二叉树
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
c2385621 小时前
map和set
数据结构·c++