码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Leetcode203/24/19-链表增加头结点的前缀节点


    链表之增加头结点的前缀节点

    • 在许多链表题中往往需要在题目给的头结点之前增加一个前缀节点
    • 通常在删除链表和头结点需要交换时需要用到这一操作
    • 因为增加这个节点就避免了对删除头结点这种特殊情况的特殊处理
    • 而且往往在声明一个前缀节点之后再复制一个,前者保存不动用于最后结果返回,后者参与之后的操作

    ​ Leetcode203删除链表元素

    • 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。
    • 输入:head = [1,2,6,3,4,5,6], val = 6
    • 输出:head = [1,2,6,3,4,5,6], val = 6
     public ListNode removeElements(ListNode head, int val) {
    
            ListNode prefinalHead=new ListNode(-1,head);
            ListNode preHead=prefinalHead;
    
            while(head!=null){
                if(head.val==val){
                    preHead.next=head.next;
                }else{
                    preHead=preHead.next;
                }
                head=head.next;
            }
    
            return prefinalHead.next;
        }
    

    Leetcode24两两交换链表中的节点

    • 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)
    • 输入:head=[1,2,3,4]
    • 输出:[2,1,4,3]
       public ListNode swapPairs(ListNode head) {
            if(head==null){//没元素
                return null;
            }
            if(head.next==null){//只有一个元素
                return head;
            }
    
           ListNode pre=head;
           ListNode post=head.next;
           ListNode finallastpre=new ListNode(-1,head);
           ListNode lastpre=finallastpre;
    
           while(pre!=null){
               if(post==null){//最后只剩一个节点
                    pre=pre.next;
               }else{
                   ListNode temp=post.next;
                   post.next=pre;
                   lastpre.next=post;
                   pre.next=temp;
                   lastpre=pre;
                   pre=pre.next;
                   if(temp!=null){
                        post=temp.next;
                   }else{
                       post=null;
                   }
                   
               }
           }
    
            return finallastpre.next; 
        }
    

    Leetcode19删除链表的倒数第N个结点

    • 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点
    • 输入:head=[1,2,3,4,5],n=2
    • 输出:[1,2,3,5]
        public ListNode removeNthFromEnd(ListNode head, int n) {
            ListNode prefinalHead=new ListNode(-1,head);
            ListNode preHead=prefinalHead;
    
            ListNode fast=head;
            ListNode slow=head;
    
            for(int i=1;i<n;i++){
                fast=fast.next;
            }
    
            while(fast.next!=null){
                slow=slow.next;
                fast=fast.next;
                preHead=preHead.next;
            }
    
            preHead.next=slow.next;
            return prefinalHead.next;
        }
    
  • 相关阅读:
    基础算法练习200题12、统计奇偶数
    VB.NET 中使用SqlConnection类连接到Microsoft SQL Server数据库的详细步骤
    爬虫逆向实战(31)-某花顺行情中心(cookie、补环境)
    C# +.Net C/S架构,在二甲医院全面实际使用三年的LIS系统源码
    yolov5 Grad-CAM可视化,以及对可视化过程的分析
    Docker的Tomcat启动报错HTTP状态404-未找到“源服务器未能找到目标资源的表示或者是不愿公开一个已经存在的
    高可用系统有哪些设计原则
    计算机网络介绍
    FPGA设计时序约束八、others类约束之Set_Case_Analysis
    全球隐私计算技术发展概览
  • 原文地址:https://www.cnblogs.com/fao99/p/16084146.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号