LeetCode 面试经典 150_链表_合并两个有序链表(58_21_C++_简单)

LeetCode 面试经典 150_链表_合并两个有序链表(58_21_C++_简单)

题目描述:

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

输入输出样例:

示例 1:

输入 :l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]

示例 2:
输入 :l1 = [], l2 = []
输出:[]

示例 3:
输入 :l1 = [], l2 = [0]
输出:[0]

提示:

两个链表的节点数目范围是 [0, 50]

-100 <= Node.val <= 100

l1 和 l2 均按 非递减顺序 排列

题解:

解题思路:

思路一(迭代):

1、通过题目分析,将两个升序链表合并为一个新的 升序 链表并返回。我们可以将两个链表中较小的结点 插入到合并链表,直至两个链表结束。

2、具体思路如下:

① 创建一个临时结点当作连接两个链表的头结点。

② 每次将值较小的结点连接到合并链表,采用尾插法进行合并。

3、复杂度分析

① 时间复杂度:O(n+m),其中 n 和 m 分别为两个链表的长度。因为每次循环迭代中,list1 和 list2 只有一个元素会被放进合并链表中, 因此 while 循环的次数不会超过两个链表的长度之和。因此总的时间复杂度为 O(n+m)。

② 空间复杂度:O(1)。我们只需要常数的空间存放若干变量。

代码实现

代码实现(思路一(迭代)):
cpp 复制代码
class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        //创建一个临时结点当作连接两个链表的头结点 
		ListNode *prehead=new ListNode(-1);
		//采用尾插法进行合并 
		ListNode *tail=prehead;
		//每次将值较小的结点连接到合并链表 
		while(list1!=nullptr&&list2!=nullptr){
			if(list1->val<list2->val){
				tail->next=list1;
				list1=list1->next;
			}else{
				tail->next=list2;
				list2=list2->next;
			}
			//每次都连接一个结点后,tail向后移动一次记录末尾 
			tail=tail->next;
		}
		//注意这里连接一个结点,就是连接一串结点(未连接部分本来就是链表) 
		tail->next=(list1!=nullptr) ? list1 : list2;
		
		//注意合并的结点是从第二个结点开始 
		return prehead->next;
    }
};
以思路一为例完成代码调试
cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

struct ListNode{
	int val;
	ListNode *next;
	ListNode():val(0),next(nullptr){}
	ListNode(int x):val(x),next(nullptr){}
	ListNode(int x,ListNode *next):val(x),next(next){}
};

//创建单链表
ListNode *createList(vector<int> arr){
	ListNode *head=nullptr,*tail=nullptr;
	for(const auto val:arr){
		ListNode* newNode=new ListNode(val);
		if(head==nullptr){
			head=newNode;
			tail=newNode;
		}else{
			tail->next=newNode;
			tail=newNode;
		}
	}
	return head;
}

class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        //创建一个临时结点当作连接两个链表的头结点 
		ListNode *prehead=new ListNode(-1);
		//采用尾插法进行合并 
		ListNode *tail=prehead;
		//每次将值较小的结点连接到合并链表 
		while(list1!=nullptr&&list2!=nullptr){
			if(list1->val<list2->val){
				tail->next=list1;
				list1=list1->next;
			}else{
				tail->next=list2;
				list2=list2->next;
			}
			//每次都连接一个结点后,tail向后移动一次记录末尾 
			tail=tail->next;
		}
		//注意这里连接一个结点,就是连接一串结点(未连接部分本来就是链表) 
		tail->next=(list1!=nullptr) ? list1 : list2;
		
		//注意合并的结点是从第二个结点开始 
		return prehead->next;
    }
};

int main(){
	vector<int> a={1,2,4};
	vector<int> b={1,3,4};
	ListNode *list1=createList(a);
	ListNode *list2=createList(b);
	Solution s;
	ListNode *mergeList=s.mergeTwoLists(list1,list2);
	while(mergeList!=nullptr){
		cout<<mergeList->val<<"->";
		mergeList=mergeList->next;
	}
	cout<<"null";
	return 0;
} 

LeetCode 面试经典 150_链表_合并两个有序链表(58_21)原题链接

欢迎大家和我沟通交流(✿◠‿◠)

相关推荐
yoke菜籽3 小时前
面试150——动态规划
1024程序员节
Dontla3 小时前
Tailwind CSS Next.js实战(官方)Tailwind Demo、Tailwind教程
1024程序员节
程琬清君3 小时前
vue3 confirm倒计时
前端·1024程序员节
麦麦大数据3 小时前
F033 vue+neo4j图书智能问答+知识图谱推荐系统 |知识图谱+neo4j+vue+flask+mysql实现代码
vue.js·flask·nlp·neo4j·智能问答·图书·1024程序员节
kaikai_sk3 小时前
达梦数据库sql笔记
1024程序员节
码以致用3 小时前
StarRocks笔记
数据库·starrocks·olap·1024程序员节
大G的笔记本3 小时前
JVM 分代收集算法(Generational GC) 的原理和执行流程
1024程序员节
这张生成的图像能检测吗3 小时前
(论文速读)开放词汇3D场景理解的掩蔽点-实体对比
人工智能·计算机视觉·图像生成·1024程序员节·开放词汇·3d重建
eguid_13 小时前
【开源项目分享】JNSM1.2.0,支持批量管理的jar包安装成Windows服务可视化工具,基于Java实现的支持批量管理已经安装服务的可视化工具
java·开源·jar·1024程序员节·windows服务·jar包安装成服务·exe安装成服务