2020--07--17 有序链表的归并

merge-two-sorted-lists

http://www.nowcoder.com/questionTerminal/a479a3f0c4554867b35356e0d57cf03d

将两个有序的链表合并为一个新链表,要求新的链表是通过拼接两个链表的节点来生成的。

示例1 
输入
{1},{}
输出
{1}

示例2 
输入
{1},{1}
输出
{1,1}

首先,判断两者都为空的状态
其次,用归并排序的合并思想,将小放前面
最后,要注意链表的特性,当某一个链表以及为空时,将另外一个链表连接到新链表
图片说明

参考代码:

 public ListNode mergeTwoLists (ListNode l1, ListNode l2) {
        // 两者为空
        if(l1==null&&l2==null){
            return null;
        }
        ListNode temp3=new ListNode(0);//head是把当前头结点记录,0不影响数据,只是占位
        ListNode head = temp3;//temp3是为了记录新链表
        ListNode temp1=l1;//temp1是为了记录链表1
        ListNode temp2=l2;//temp2是为了记录链表2
        while(true){
            if(temp2==null){//第二个链表为空,把第一个链表接上,break
                temp3.next=temp1;
                break;
            }else if(temp1==null){//第一个链表为空,把第二个链表接上,break
                temp3.next=temp2;
                break;
            }else if(temp1.val<=temp2.val){//第一个链表小于第二个链表的值,把第一个链表的val给新链表
                temp3.next=temp1;
                temp1=temp1.next;
                temp3 = temp3.next;//注意temp1和temp3都要后移
            }else{//否则把第二个链表的val给新链表
                temp3.next=temp2;
                temp2=temp2.next;
                temp3 = temp3.next;//注意temp2和temp3都要后移
            }
        }
        return head.next;//返回的是头节点的next
    }
全部评论
最后为什么返回头结点的next
1 回复 分享
发布于 2020-11-28 09:35
ListNode根本没有带参构造函数
1 回复 分享
发布于 2020-10-03 23:31

相关推荐

bg双非本科,方向是嵌入式。这次秋招一共拿到了&nbsp;8&nbsp;个&nbsp;offer,最高年包&nbsp;40w,中间也有一段在海康的实习经历,还有几次国家级竞赛。写这篇不是想证明什么,只是想把自己走过的这条路,尽量讲清楚一点,给同样背景的人一个参考。一、我一开始也很迷茫刚决定走嵌入式的时候,其实并没有一个特别清晰的规划。网上的信息很零散,有人说一定要懂底层,有人说项目更重要,也有人建议直接转方向。很多时候都是在怀疑:1.自己这种背景到底有没有机会2.现在学的东西到底有没有用3.是不是已经开始晚了这些问题,我当时一个都没答案。二、现在回头看,我主要做对了这几件事第一,方向尽早确定,但不把自己锁死。我比较早就确定了嵌入式这个大方向,但具体做哪一块,是在项目、竞赛和实习中慢慢调整的,而不是一开始就给自己下结论。第二,用项目和竞赛去“证明能力”,而不是堆技术名词。我不会刻意追求学得多全面,而是确保自己参与的每个项目,都能讲清楚:我负责了什么、遇到了什么问题、最后是怎么解决的。第三,尽早接触真实的工程环境。在海康实习的那段时间,对我触动挺大的。我开始意识到,企业更看重的是代码结构、逻辑清晰度,以及你能不能把事情说清楚,而不只是会不会某个知识点。第四,把秋招当成一个需要长期迭代的过程。简历不是一次写完的,面试表现也不是一次就到位的。我会在每次面试后复盘哪些问题没答好,再针对性补。三、我踩过的一些坑现在看也挺典型的:1.一开始在底层细节上纠结太久,投入产出比不高2.做过项目,但前期不会总结,导致面试表达吃亏3.早期有点害怕面试,准备不充分就去投这些弯路走过之后,才慢慢找到节奏。四、给和我背景相似的人一点建议如果你也是双非,准备走嵌入式,我觉得有几件事挺重要的:1.不用等“准备得差不多了”再投2.项目一定要能讲清楚,而不是做完就算3.不要只盯着技术,多关注表达和逻辑很多时候,差的不是能力,而是呈现方式。五、写在最后这篇总结不是标准答案,只是我个人的一次复盘。后面我会陆续把自己在嵌入式学习、竞赛、实习和秋招中的一些真实经验拆开来讲,希望能对后来的人有点帮助。如果你正好也在这条路上,希望你能少走一点弯路。
点赞 评论 收藏
分享
评论
7
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务