合并有序链表

合并有序链表

图解

虽然很复杂,但能够很好的理解怎么使用链表,以及对链表的指针类理解

代码如下

cpp 复制代码
Node* merge_list_two_pointer(List& list1, List& list2)
{
	Node* new_head1 = list1.head;
	Node* new_head2 = list2.head;
	Node* sentinel1 = list1.head;
	Node* sentinel2 = list2.head;
	Node* temp_head1 = NULL;
	Node* temp_head2 = NULL;
	int flage = 1;
	//因为下面是<=,所以以list2优先为空
	if (new_head1->data >= new_head2->data)
	{
		flage = 2;
	}
	while (new_head1 != NULL && new_head2 != NULL)
	{
		while (list1.head != NULL && list1.head->data < list2.head->data)
		{
			temp_head1 = list1.head;
			list1.head = list1.head->next;
		}
		//正常两个有序列表,上面为空,
		//456,123456789
		if (list1.head == NULL && flage == 2)
		{
			temp_head1->next = list2.head;
			return sentinel2;
		}
		//特殊情况列表,全大
		//123,456
		if (list1.head == NULL)
		{
			temp_head1->next = new_head2;
			return sentinel1;
		}
		if (temp_head1 != NULL)
		{
			temp_head1->next = new_head2;
		}

		while (list2.head != NULL && list2.head->data <= list1.head->data)
		{
			temp_head2 = list2.head;
			list2.head = list2.head->next;
		}
		//正常两个有序列表,下面为空
		//123456789,456
		if (list2.head == NULL && flage == 1)
		{
			temp_head2->next = list2.head;
			return sentinel1;
		}
		//特殊情况列表也就是,全小
		//456,123
		if (list2.head == NULL)
		{
			//防止89,89这种类型链表跑空
			temp_head2->next = list1.head;
			return sentinel2;
		}
		//这里不需要判断这个为空。如果为空,则说明已经到达链表尾部
		temp_head2->next = list1.head;

		new_head1 = list1.head;
		new_head2 = list2.head;
	}
}
相关推荐
vortex513 分钟前
Windows权限与icacls命令详解
windows·网络安全·渗透测试·操作系统
ABCDEEE728 分钟前
人事管理系统6
windows·sql·mybatis
Linux运维老纪1 小时前
Ansible 守护 Windows 安全(Ansible Safeguards Windows Security)
linux·windows·网络安全·自动化·云计算·运维开发·asible
菜还不练就废了1 小时前
数据结构|并查集
数据结构·算法
MyhEhud2 小时前
kotlin flatMap 变换函数的特点和使用场景
开发语言·windows·kotlin
元亓亓亓2 小时前
LeetCode热题100--53.最大子数组和--中等
数据结构·算法·leetcode
ttk2193 小时前
【算法练习】归并排序和归并分治
数据结构·c++·算法·排序算法
梁辰兴4 小时前
数据结构:实验7.3Huffman树与Huffman编码
数据结构·c++·算法·c
乌鸦9445 小时前
《数据结构之美--二叉树oj题练习》
数据结构·#二叉树练习
keep intensify6 小时前
数据结构---单链表的增删查改
c语言·数据结构·c++·经验分享·学习·算法·分享