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
相关推荐
Queenie_Charlie1 小时前
关于二叉树
数据结构·c++·二叉树
嘻嘻哈哈樱桃2 小时前
牛客经典101题解题集--二分查找/排序
数据结构·算法·职场和发展
沉默金鱼3 小时前
读书笔记——U3D高级编程:主程手记——第二章2.2List底层源码
数据结构·list
故事和你914 小时前
洛谷-算法2-1-前缀和、差分与离散化1
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
田梓燊11 小时前
力扣:19.删除链表的倒数第 N 个结点
算法·leetcode·链表
阿豪学编程13 小时前
面试题map/unordered相关
数据结构
武藤一雄13 小时前
19个核心算法(C#版)
数据结构·windows·算法·c#·排序算法·.net·.netcore
梦想的颜色14 小时前
mongoTemplate + Java 增删改查基础介绍
数据结构·数据库·mysql
叶小鸡16 小时前
小鸡玩算法-力扣HOT100-堆
数据结构·算法·leetcode