当前位置:   article > 正文

2024年最新【力扣】【面试:单链表1】合并两个有序链表,前端开发网络培训

2024年最新【力扣】【面试:单链表1】合并两个有序链表,前端开发网络培训
总结

三套“算法宝典”

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

28天读完349页,这份阿里面试通关手册,助我闯进字节跳动

算法刷题LeetCode中文版(为例)

人与人存在很大的不同,我们都拥有各自的目标,在一线城市漂泊的我偶尔也会羡慕在老家踏踏实实开开心心养老的人,但是我深刻知道自己想要的是一年比一年有进步。

最后,我想说的是,无论你现在什么年龄,位于什么城市,拥有什么背景或学历,跟你比较的人永远都是你自己,所以明年的你看看与今年的你是否有差距,不想做咸鱼的人,只能用尽全力去跳跃。祝愿,明年的你会更好!

由于篇幅有限,下篇的面试技术攻克篇只能够展示出部分的面试题,详细完整版以及答案解析,有需要的可以关注


源码实现:

=======================================================================

/**

  • Definition for singly-linked list.

  • public class ListNode {

  • int val;
    
    • 1
  • ListNode next;
    
    • 1
  • ListNode() {}
    
    • 1
  • ListNode(int val) { this.val = val; }
    
    • 1
  • ListNode(int val, ListNode next) { this.val = val; this.next = next; }
    
    • 1
  • }

*/

class Solution {

public ListNode mergeTwoLists(ListNode list1, ListNode list2) {

ListNode newHead = new ListNode(-1024);

ListNode pt = newHead;

if(list1==null){

return list2;

}

if(list2==null){

return list1;

}

while(list1!=null && list2!=null){

if(list1.val<=list2.val){

ListNode tNode = new ListNode (list1.val);

pt.next=tNode;

pt=pt.next;

list1=list1.next;

}else{

ListNode tNode = new ListNode (list2.val);

pt.next=tNode;

pt=pt.next;

list2=list2.next;

}

}

if(list1==null){

pt.next=list2;

}else{

pt.next=list1;

}

return newHead.next;

}

}

/**

  • Definition for singly-linked list.

  • public class ListNode {

  • int val;
    
    • 1
  • ListNode next;
    
    • 1
  • ListNode() {}
    
    • 1
  • ListNode(int val) { this.val = val; }
    
    • 1
  • ListNode(int val, ListNode next) { this.val = val; this.next = next; }
    
    • 1
  • }

*/

class Solution {

public ListNode mergeTwoLists(ListNode list1, ListNode list2) {

ListNode newHead = new ListNode(-1024);

ListNode pt = newHead;

if(list1==null){

return list2;

}

if(list2==null){

return list1;

}//两个链表其中一个为空返回另一个,两个都为空,在上一个if判断里返回list2仍然为空

while(list1!=null && list2!=null){//循环不变量必须两个都不为空同时进行!

if(list1.val<=list2.val){

ListNode tNode = new ListNode (list1.val);//注意声明的新节点往新链表中放

pt.next=tNode;

pt=pt.next;

list1=list1.next;

}else{

ListNode tNode = new ListNode (list2.val);

pt.next=tNode;//新节点插入新链表

pt=pt.next;//原两个链表中一个节点已经被接上

list2=list2.next;//移动新链表上的指针向后

}

}

if(list1==null){//退出循环,一个已经用完!

pt.next=list2;

}else{

pt.next=list1;

}

return newHead.next;//注意返回值应该是新链表的第二个结点(从第二个开始有效)
}
}

总结

三套“算法宝典”

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

28天读完349页,这份阿里面试通关手册,助我闯进字节跳动

算法刷题LeetCode中文版(为例)

人与人存在很大的不同,我们都拥有各自的目标,在一线城市漂泊的我偶尔也会羡慕在老家踏踏实实开开心心养老的人,但是我深刻知道自己想要的是一年比一年有进步。

最后,我想说的是,无论你现在什么年龄,位于什么城市,拥有什么背景或学历,跟你比较的人永远都是你自己,所以明年的你看看与今年的你是否有差距,不想做咸鱼的人,只能用尽全力去跳跃。祝愿,明年的你会更好!

由于篇幅有限,下篇的面试技术攻克篇只能够展示出部分的面试题,详细完整版以及答案解析,有需要的可以关注

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号