会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 133905个问题
Python 全系列/第一阶段:AI驱动的Python编程/面向对象 19936楼

老师好,关于单链表做算法题时候遇到如下代码:





/**
 * 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 mergeTwoLists(ListNode l1, ListNode l2) {
        ListNode dummy= new ListNode(-1);
        ListNode curr= dummy;
        
        while(l1 !=null || l2 !=null){
            int x = (l1 == null)? Integer.MAX_VALUE: l1.val;
            int y = (l2 == null)? Integer.MAX_VALUE: l2.val;     
            if(x<y){
                curr.next=new ListNode(x);
                l1=l1.next;
            }else{
                curr.next=new ListNode(y);
                l2=l2.next;
            }
            curr=curr.next;    
        }
        return dummy.next;
    }
}



我的问题在20行和23行的

curr.next


因为这两部是将dummy链表往后推进,因为curr指向dummy,所以curr.next实际就是指向dummy链表的下一个节点。


但是这里我不懂,为什么不能用

dummy.next=...


这不是同样也表示dummy的下一个节点指向一个新的listnode?

因为我试了下,这样做会报错。谢谢




JAVA 全系列/第二阶段:JAVA 基础深化和提高/数据结构 19937楼

D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34\bin\catalina.bat run

Configuration Error: deployment source 'ssm-shiro:war exploded' is not valid

[2021-07-03 11:48:30,077] Artifact ssm-shiro:war exploded: Error during artifact deployment. See server log for details.

Using CATALINA_BASE:   "C:\Users\yc\.IntelliJIdea2019.3\system\tomcat\Tomcat_9_0_34_shiro1"

Using CATALINA_HOME:   "D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34"

Using CATALINA_TMPDIR: "D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34\temp"

Using JRE_HOME:        "C:\Program Files\Java\jdk-13.0.2"

Using CLASSPATH:       "D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34\bin\bootstrap.jar;D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34\bin\tomcat-juli.jar"

NOTE: Picked up JDK_JAVA_OPTIONS:  --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED

03-Jul-2021 23:48:30.903 警告 [main] org.apache.catalina.startup.ClassLoaderFactory.validateFile Problem with directory [D:\JDK??????????\Servlet\apache-tomcat-9.0.34\lib], exists: [false], isDirectory: [false], canRead: [false]

03-Jul-2021 23:48:30.906 警告 [main] org.apache.catalina.startup.ClassLoaderFactory.validateFile Problem with directory [D:\JDK??????????\Servlet\apache-tomcat-9.0.34\lib], exists: [false], isDirectory: [false], canRead: [false]

03-Jul-2021 23:48:31.302 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log Server.服务器版本:     Apache Tomcat/9.0.34

03-Jul-2021 23:48:31.303 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 服务器构建:            Apr 3 2020 12:02:52 UTC

03-Jul-2021 23:48:31.303 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 服务器版本号(:9.0.34.0

03-Jul-2021 23:48:31.303 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Windows 10

03-Jul-2021 23:48:31.303 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log OS.版本:               10.0

03-Jul-2021 23:48:31.303 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 架构:                  amd64

03-Jul-2021 23:48:31.304 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log Java 环境变量:         C:\Program Files\Java\jdk-13.0.2

03-Jul-2021 23:48:31.304 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log JVM 版本:              13.0.2+8

03-Jul-2021 23:48:31.304 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log JVM.供应商:            Oracle Corporation

03-Jul-2021 23:48:31.304 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_BASE:[C:\Users\yc\.IntelliJIdea2019.3\system\tomcat\Tomcat_9_0_34_shiro1]

03-Jul-2021 23:48:31.305 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_HOME:         D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[--add-opens=java.base/java.lang=ALL-UNNAMED]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[--add-opens=java.base/java.io=ALL-UNNAMED]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[--add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Djava.util.logging.config.file=C:\Users\yc\.IntelliJIdea2019.3\system\tomcat\Tomcat_9_0_34_shiro1\conf\logging.properties]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Dcom.sun.management.jmxremote=]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Dcom.sun.management.jmxremote.port=1099]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Dcom.sun.management.jmxremote.ssl=false]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Dcom.sun.management.jmxremote.password.file=C:\Users\yc\.IntelliJIdea2019.3\system\tomcat\Tomcat_9_0_34_shiro1\jmxremote.password]

03-Jul-2021 23:48:31.307 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Dcom.sun.management.jmxremote.access.file=C:\Users\yc\.IntelliJIdea2019.3\system\tomcat\Tomcat_9_0_34_shiro1\jmxremote.access]

03-Jul-2021 23:48:31.308 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Djava.rmi.server.hostname=127.0.0.1]

03-Jul-2021 23:48:31.308 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Djdk.tls.ephemeralDHKeySize=2048]

03-Jul-2021 23:48:31.308 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Djava.protocol.handler.pkgs=org.apache.catalina.webresources]

03-Jul-2021 23:48:31.308 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Dignore.endorsed.dirs=]

03-Jul-2021 23:48:31.308 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Dcatalina.base=C:\Users\yc\.IntelliJIdea2019.3\system\tomcat\Tomcat_9_0_34_shiro1]

03-Jul-2021 23:48:31.308 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Dcatalina.home=D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34]

03-Jul-2021 23:48:31.309 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log 命令行参数:[-Djava.io.tmpdir=D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34\temp]

03-Jul-2021 23:48:31.309 信息 [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent Loaded APR based Apache Tomcat Native library [1.2.23] using APR version [1.7.0].

03-Jul-2021 23:48:31.309 信息 [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent APR capabilities: IPv6 [true], sendfile [true], accept filters [false], random [true].

03-Jul-2021 23:48:31.309 信息 [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent APR/OpenSSL配置:useAprConnector[false],useOpenSSL[true]

03-Jul-2021 23:48:31.314 信息 [main] org.apache.catalina.core.AprLifecycleListener.initializeSSL OpenSSL successfully initialized [OpenSSL 1.1.1c  28 May 2019]

03-Jul-2021 23:48:31.489 信息 [main] org.apache.coyote.AbstractProtocol.init 初始化协议处理器 ["http-nio-8080"]

03-Jul-2021 23:48:31.873 信息 [main] org.apache.catalina.startup.Catalina.load 服务器在[893]毫秒内初始化

03-Jul-2021 23:48:31.922 信息 [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina]

03-Jul-2021 23:48:31.922 信息 [main] org.apache.catalina.core.StandardEngine.startInternal 正在启动 Servlet 引擎:[Apache Tomcat/9.0.34]

03-Jul-2021 23:48:32.534 警告 [main] org.apache.catalina.util.SessionIdGeneratorBase.createSecureRandom Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [345] milliseconds.

03-Jul-2021 23:48:32.561 信息 [main] org.apache.coyote.AbstractProtocol.start 开始协议处理句柄["http-nio-8080"]

03-Jul-2021 23:48:32.572 信息 [main] org.apache.catalina.startup.Catalina.start Server startup in [698] milliseconds

Connected to server

Configuration Error: deployment source 'ssm-shiro:war exploded' is not valid

[2021-07-03 11:48:32,744] Artifact ssm-shiro:war exploded: Error during artifact deployment. See server log for details.

03-Jul-2021 23:48:42.571 信息 [Catalina-utility-2] org.apache.catalina.startup.HostConfig.deployDirectory 把web 应用程序部署到目录 [D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34\webapps\manager]

03-Jul-2021 23:48:42.679 信息 [Catalina-utility-2] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [D:\JDK配置和视频\Servlet\apache-tomcat-9.0.34\webapps\manager] has finished in [108] ms



这个错误是什么意思啊???

JAVA 全系列/第十阶段:权限控制与安全认证/Shiro(旧) 19940楼

package com.bjsxt;

import java.io.*;
import java.util.ArrayList;
import java.util.List;

public class ObjectStreamObjectTypeDemo {


    public void ObjectOutputStreamObjectTypeDem(List<Person> list) {
        ObjectOutputStream oos = null;
        List<Person> list1 = new ArrayList<>();
        try {
            oos = new ObjectOutputStream(new BufferedOutputStream(new FileOutputStream("J:\\课堂练习\\课程目录\\01.02JAVA入门与深化提高\\智能电话本项目实战\\电话簿.txt")));
            for (int i = 0; i < list.size(); i++) {
                list1.add(list.get(i));
            }
            oos.writeObject(list1);
            oos.flush();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (oos != null) {
                    oos.close();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

    public List<Person> ObjectInputStreamObjectTypeDemo(List<Person> list) {
        ObjectInputStream ois = null;
        List<Person> ls = null;
        try {
            ois = new ObjectInputStream(new BufferedInputStream(new FileInputStream("J:\\课堂练习\\课程目录\\01.02JAVA入门与深化提高\\智能电话本项目实战\\电话簿.txt")));
            ls = (List<Person>) ois.readObject();
            for(int i = 0;i<ls.size();i++){
                list.add(ls.get(i));
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (ois != null) {
                    ois.close();
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        return list;
    }
}

老师的课堂作业,我写了一个类,然后在Operate 类中加了两个方法,一个是在退出时调用类下的方法 将list 遍历到自定义的数组然后将数组序列化到本地文件,

public void exit(){
    ObjectStreamObjectTypeDemo os = new ObjectStreamObjectTypeDemo();
    os.ObjectOutputStreamObjectTypeDem(this.list);
    System.exit(0);;
}

一个是初始化,运行项目时就调用类下的方法将文件的内容读到自定义数组 然后遍历给list,

/**
 * 传入电话薄
 */
public void Initialize(){
    ObjectStreamObjectTypeDemo os = new ObjectStreamObjectTypeDemo();
    os.ObjectInputStreamObjectTypeDemo(this.list);
}

image.png

不知道对不对,功能可以实现。就是我给的都是绝度路径,不知道怎么设定为相对路径,不知道制作成Jar包,能不能用

JAVA 全系列/第二阶段:JAVA 基础深化和提高/IO 流技术(旧) 19941楼
微服务/第一阶段:SSM 框架和项目开发/(旧)Mybatis 19942楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 19945楼
JAVA 全系列/第十四阶段:全文检索服务/Spring Data For ElasticSearch 19947楼
人工智能/第五阶段:机器学习-线性回归/Lasso回归_Ridge回归_多项式回归 19948楼
JAVA 全系列/第四阶段:数据库与AI协同技术实战/Oracle 数据库的使用 19949楼
Python 全系列/ 第十五阶段:自动化操作办公软件、邮件、定时任务等/自动化操作办公软件、邮件、定时任务等 19950楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637