首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

合并有序链表

第二部进入到了第二层,这时候new_list 又被赋值指向了B,但是你要记住在内存中A并没有变化,有的只是new_list这个代号被B用了,这时候B就自然而然的承接在A的下面然后B的下一位节点必然是其余中的最小的...以此类推,等递归到最后一层的时候,每次返回必然会自然而然的承接上自己的头结点,递归结束后的new_list便指向新链表的头结点的地址。...不用递归的话要先手判断,两个链表的头结点的值,取其中小的,用两个变量进行存储。为什么要两个,因为一个用于循环是一层层往下面加节点,一个用于返回,不然你循环完了,却又给不出头结点,那不就废了嘛。...            System.out.println(end.val);             end = end.next;         }     }     /**      * 使用递归的方式进行合并两个列表...new_list.next = mergeTwoLists2(l1, l2.next);         }         return new_list;     }     /**      * 使用循环的方式进行合并两个列表

20020

漫谈递归-链表合并

第一个题目 合并两个有序链表 认真阅读题目 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。...示例: 输入:1->2->4, 1->3->4 输出:1->1->2->3->4->4 线索 递归实现 新链表 是有将两个有序链表合并成的 假设有方法mergeTwoLists能实现这样功能。...难度升级 第二个问题 合并K个排序链表 认真阅读题目 合并K个排序链表 合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。...这是k个 不是2个 感觉无从下手,转成成22合并 问题2. k个链表如何,通过什么方式知道 已经完成排序了呢。...步骤 1.如果是一个链表(从最简单开始) 就不需要合并 这就是结果 如果是多个 采用归并排序。对象就是n个链表。 ?

61420
您找到你想要的搜索结果了吗?
是的
没有找到

【Leetcode】反转链表 合并链表 相交链表 链表的回文结构

【Leetcode21】合并两个有序链表 1.链接 合并两个有序链表 2.题目再现 3.三指针尾插法 思路:创建一个新的链表,分别遍历两个链表,小的就尾插到新链表,然后指针向后走一步,直到有一方为空时就结束循环...分表遍历两个链表,比较其值,小的尾插到新链表,并向后走一步(如果一样大,那么随便取哪一个都行); 4.结束循环后,判断哪个链表不为空,尾插到新链表。...动态演示: 合并两个有序链表动态演示 代码: struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2)...【Leetcode160】相交链表 1.链接 相交链表 2.题目再现 3.解法 1.先分别遍历两个链表,记录下两个链表的长度; 2.如果两个链表尾节点的地址一样,则说明它们相交,否则不相交,(注意是地址不是值...); 3.求出两个链表长度的差gap; 4.先让长的链表走差距步gap,短的链表先不动; 5.然后两个链表同时走一步,比较每走一步时两个链表当前节点的地址,如果一样,则说明找到了它们相交的起始位置

10310

4 合并有序链表

本文涉及知识点  哨兵结点的运用 链表数据结构中哨兵的作用在之前详细阐述了[leetcode链表系列]2 删除链表中的节点,忘记了的小伙伴复习后再看效果一定翻倍哟!...1 Leetcode21 合并有序链表 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。...01 题目解析 思路 为了方便返回合并后的链表,我们使用head为头结点,p1,p2分别跟踪两链表L1,L2.如下图。 ? 如果p1当前值小于p2的值,我们就将p1的值直接连接在pre后面并移动p1。...循环结束的时候,如果有一个链表非空,因为两链表均有序,将其合并到另个链表即可。 今天小蓝没有把具体完整的画出来,想着做了一个带bgm的动画,大家可以放松放松的看看。

41720

合并两个有序链表

合并两个有序链表 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 ?...,判断 l1 和 l2 哪一个链表的头节点的值更小,将较小值的节点添加到结果里,当一个节点被添加到结果里之后,将对应链表中的节点向后移一位。...由于输入的两个链表都是有序的,所以不管哪个链表是非空的,它包含的所有元素都比前面已经合并链表中的所有元素都要大。...这意味着我们只需要简单地将非空链表接在合并链表的后面,并返回合并链表即可 /** * Definition for singly-linked list....l2 : l1 return listNode.next }; 解法二:递归 思路:如果 l1 或者 l2 一开始就是空链表 ,那么没有任何操作需要合并,所以我们只需要返回非空链表

1.4K30

合并两个有序链表

合并两个有序链表,使得合并后的结果仍然是有序的,直观的做法就是从两个链表的首节点开始比较,将其中小的那个链接到新链表之中,(如果不想破坏原链表,那么需要将该节点拷贝一份,然后链接到新链表之中。)...void Print(List L); //遍历链表 List Merge(List L1, List L2); //合并链表 int main() { List L1, L2, L; /.../构造L1和L2链表 L1 = Read(); L2 = Read(); //合并L1和L2链表 L = Merge(L1, L2); //合并后的结果 Print(L); printf(...} } if (NULL == p1) { p3->Next = p2; } if (NULL == p2) { p3->Next = p1; } //此处在原节点的基础上合并两个链表...,破坏掉了原链表,使得原链表为空 L1->Next = NULL; L2->Next = NULL; //返回新链表的头指针 return p; } 这种使用双指针的方法,不止在合并链表的时候会用到

5.1K20

合并两个有序链表

题目描述 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。...吴师兄的思路 当 l1 和 l2 都不为空时,判断 l1 和 l2 哪一个链表的头节点的值更小,将较小值的节点添加到结果中,当一个节点被添加到结果中之后,将对应链表中的节点向后移一位,查看和对比下一个节点...具体操作如下: 1、由于需要对比两个链表的头节点,为了让两个原链表的头节点的地位与其它节点的地位一样,避免做其它额外的判断处理,这里设定一个虚拟头节点 dummy ,方便后续返回合并后的链表 2、维护一个...5、循环重复上述的 3 和 4 操作,直到 l1 或者 l2 其中任何一个指向了 null 为止,也即遍历完 l1 或者 l2 中的任意一个链表为止。...它包含的所有元素都比前面已经合并链表中的所有元素都要大。

1.4K80

合并两个排序链表

题意 将两个排序链表合并为一个新的排序链表 样例 给出 1->3->8->11->15->null,2->null, 返回 1->2->3->8->11->15->null。...思路 这道题很简单,属于链表的基本操作。 只需要创建一个新的链表与一个指向新链表最后一个节点的指针即可。...当 l1 与 l2 均不为空的情况下,判断 l1 和 l2的大小,把较小值放进新链表的最后一个节点,然后将较小值所处的链表向后移一位,以判断下一个数。...依次循环,直到 l1 或 l2 中有一方为空时,将为空的一方,直接加到新链表后即可。 代码实现 /** * Definition for ListNode....= l2; if (l2 == null) { lastNode.next = l1; } return listNode.next; } } 原题地址 LintCode:合并两个排序链表

1.5K10

合并两个有序链表

合并两个有序链表 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。...,定义一个指针p3始终指向新链表的最后一个节点,定义一个指针ptmp指向新链表的头结点。...每一次循环都比较两个指针指向节点的值,将偏小的节点加到新链表中(若相等则将p2加到新链表中),且较小的链表上的指针往后移动一位。 当p1、p2任意next节点为空时,将非空节点加到新链表中。...7.同步骤4 循环执行,直到一方指针为空跳出循环 将非空指针指向的节点加到已排序的链表里,此时返回ptmp->next即为合并后的链表 代码 /** * Definition for singly-linked...->将原链表指针向后移动->将新链表指针向后移动 当循环结束后,把原链表非空指针指向的节点加到已排序的链表中即可,返回虚拟头结点的next节点,即可得到合并后的有序链表

16720
领券