数据结构之“合并两个有序链表”

一、后插法

1、定义:

通过将新节点逐个插入到链表的尾部来创建链表。

2、特点:

(1)每次申请一个新节点,读入相应的数据元素值

(2)为了使新节点能够插入到表尾,需要增加一个尾指针 r 指向链表的尾结点

3、图示:

4、代码实现:

cpp 复制代码
//----------单链表的存储结构----------
typedef struct LNode{
	ElemType data;
	struct LNode *next;
}LNode, *LinkList;
cpp 复制代码
void CreateList_R(LinkList &L, int n)
{
	L = new LNode;
	L->next = NULL;
	r = L;
	for(i=0; i<n; i++)
	{
		p = new LNode;
		cin>>p->data;
		p->next = NULL;
		r->next = p;
		r = p;
	}
}

二、"合并两个有序链表"

1、题目:

2、解题思路:

此题可以先创建一个空链表,然后依次从两个有序链表中选取最小的进行尾插操作进行合并

3、代码实现:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {
    if(list1 == NULL)
        return list2;
    if( list2 == NULL)
        return list1;
    
    struct ListNode* p = (struct ListNode*)malloc(sizeof(struct ListNode));
    p->next = NULL;
    struct ListNode* q = (struct ListNode*)malloc(sizeof(struct ListNode));
    q->next = NULL;
    q = p;
    while(list1 && list2)
    {
        struct ListNode* l1 = list1;
        struct ListNode* l2 = list2;
        if(l1->val >= l2->val)
        {
            list2 = list2->next;
            p->next = l2;
            p = p->next;
        }
        else
        {
            list1 = list1->next;
            p->next  =l1;
            p = p->next;
        }
    }

    if(list1)
        p->next = list1;
    if(list2)
        p->next = list2;
    return q->next;
}

4、测试用例:

微语:You want this life, these choise are necessary.

(最近在看《穿普拉达的女王》,里面的女性太帅了!!)

相关推荐
ID_1800790547326 分钟前
淘宝商品详情数据接口深度解析:架构、鉴权、数据结构与实战
数据结构·架构
散峰而望1 小时前
【算法练习】算法练习精选:陶陶摘苹果(基础+升级)、Music Notes、字串变换,你能AC几道?
数据结构·c++·算法·leetcode·贪心算法·github·动态规划
凤凰院凶涛QAQ1 小时前
《Java版数据结构 & 集合类剖析》集合框架的封装设计与顺序表:“从 Iterable 到 ArrayList:集合框架的‘职业树“
java·开发语言·数据结构
8Qi82 小时前
LeetCode 148. 排序链表 —— 解法二:自底向上归并(迭代,O(1) 空间)
数据结构·算法·leetcode·链表·归并·迭代
嘿黑嘿呦2 小时前
数据结构-图论-最小生成树
数据结构·算法·图论
欧米欧3 小时前
C++进阶数据结构之红黑树
数据结构
papership3 小时前
【入门级-数据结构-1、线性结构:链 表(单链表、双向链表、循环链表 )】
数据结构·算法·链表
csdn_aspnet3 小时前
C++ 霍尔分区算法(Hoare‘s Partition Algorithm)
数据结构·c++·算法
不知名的老吴3 小时前
熟练掌握Python,可数据结构和算法还是很难?
数据结构
无限进步_3 小时前
【Linux】进度条:行缓冲区、\r 与 fflush 的实战
linux·服务器·开发语言·数据结构·后端