首页 > 编程语言 >【基础算法】单链表的OJ练习(1) # 反转链表 # 合并两个有序链表 #

【基础算法】单链表的OJ练习(1) # 反转链表 # 合并两个有序链表 #

时间:2023-06-12 23:32:45浏览次数:44  
标签:单链 OJ next 链表 l2 l1 节点 cur

前言

  • 上一章讲解了单链表 ==->== 传送门 ==<-== ,后面几章就对单链表进行一些简单的题目练习,目的是为了更好的理解单链表的实现以及加深对某些函数接口的熟练度。

  • 本章带来了两个题目。一是<font color=red>反转链表</font>,二是<font color=red>合并两个有序链表</font>,整体难度不大,但要理清解题思路。

反转链表

题目链接 ==->== 传送门 ==<-==

  • 该题目的意思是将一个单链表反转过来,单链表的尾节点变成新的头节点,头节点变成新的尾节点:

在这里插入图片描述

  • 题目描述是,给你一个单链表的头节点 head ,请你反转链表,并返回反转后的链表。

  • 返回反转后的链表也就是返回反转后的链表的头节点。

<font color=red size=4>思路一:</font>

  • 创建一个新的链表,取原链表的元素依次==头插==即可,最后返回这个新的链表的头节点。

在这里插入图片描述

<font color=red size=4>思路二:</font>

  • 直接修改原链表,返回原链表的尾节点(反转后的头节点)即可。

  • 定义三个指针遍历原链表,三个指针 ==(prev,cur,tail)== prev开始指向NULL,cur指向头节点,tail指向cur 的下一个节点(为了找到下一个)。具体操作就是cur->next = prev(将指针改变指向),然后prev = cur,cur = tailtail = cur->next(该语句在循环的开头)。这样又是三个指针指向不同的节点,然后再将cur的指针指向前一个prev,整个过程其实就是一个循环。

  • 循环的条件是cur不为NULL就继续,当cur为空,也就是最后一步cur = tail,此时cur,tail都为空,而prev刚好指向原链表的最后一个节点,所以最后返回prev就可以了。

在这里插入图片描述

<font color=blue size=4>这里采用思路二进行代码实现:</font>

struct ListNode* reverseList(struct ListNode* head){
    struct ListNode* cur = head;
    struct ListNode* prev =  NULL;
    while (cur)
    {
        struct ListNode* tail = cur->next;
        cur->next = prev;
        prev = cur;
        cur = tail;
    }

    return prev;
}

合并两个有序链表

题目链接 ==->== 传送门 ==<-==。

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

在这里插入图片描述

  • 该题与归并排序的排序思路差不多。本题需要创建一个新链表。之后采用双指针分别遍历上下两个链表,那个节点的数据较小,就在新的链表中尾插该节点,然后指向该节点的指针向后移动一位。整体来说就是一个循环,循环结束的条件就是两个指针都指向了NULL或者其中一个指针指向了NULL

  • 注意,我们这里的新链表是不带哨兵位的,当然带哨兵位可能更加方便,最后需要返回哨兵位的下一个节点的指针。

  • 如果循环结束后,有一个指针没有指向NULL,那么在后面还需要将剩余的节点依次尾插,直到两个指针都为NULL合并成功。

在这里插入图片描述

<font color=blue size=4>代码实现:</font>

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {
    struct ListNode* l1 = list1, * l2 = list2;  // 两个指针分别指向两个链表的头
    struct ListNode* head = NULL, * cur = NULL;  // 新链表的头和进行操作的指针cur
    while (l1 && l2)   // 有一个指向空就结束
    {
        if (l1->val < l2->val)  // 比较数据值
        {
            if (!head) head = cur = l1;   // 这个if是如果新链表为空,就将该节点作为头节点
            else cur->next = l1, cur = cur->next;
            l1 = l1->next;
        }
        else
        {
            if (!head) head = cur = l2;
            else cur->next = l2, cur = cur->next;
            l2 = l2->next;
        }
    }
    // 如果l1不为空说明l1还有节点没有尾插完,需继续尾插
    while (l1)
    {
        if (!head) head = cur = l1;
        else cur->next = l1, cur = cur->next;
        l1 = l1->next;
    }
    // 如果l2不为空说明l2还有节点没有尾插完,需继续尾插
    while (l2)
    {
        if (!head) head = cur = l2;
        else cur->next = l2, cur = cur->next;
        l2 = l2->next;
    }
	
	// 最后返回新链表的头节点
    return head;
}

写在最后

<font color=red size=4>对于单链表的题目练习,最重要的是思路,我们在数据结构阶段要养成画图的习惯,因为它能帮助我们更好的理解。后续还会有单链表相关的题目练习。</font>

<font color=blue size=4>感谢阅读本小白的博客,错误的地方请严厉指出噢!</font>

标签:单链,OJ,next,链表,l2,l1,节点,cur
From: https://blog.51cto.com/u_16019252/6466523

相关文章

  • dojo\dart脚本编程语言
    Dojo是一个用于构建高效、可扩展的Web应用程序的开源JavaScript框架。它提供了一系列功能丰富的模块和组件,包括DOM操作、事件处理、异步编程、动画效果等。Dojo还具有强大的用户界面(UI)工具包Dijit,可以帮助开发人员轻松实现各种复杂的界面交互。Dojo的主要特点包括:1.模块化:Dojo采......
  • 「UOJ700」可爱多的字符串
    题目有一次机灵鬼和学长可爱多打比赛,可爱多不会做一道字符串题,机灵鬼做了很久终于做出来了,这是机灵鬼第一次做出可爱多不会的题。可爱多觉得很丢人,于是准备研究字符串。可爱多精通\(\mathrm{kmp}\)算法。\(\mathrm{kmp}\)算法的输入是一个字符串\(S\),该算法的核心是对每个......
  • Open Project 系列2 --- 集成LDAP
    一、概要1.承上启下OpenProject系列二、配置1.配置页面OpenProject可以通过页面来配置LDAP。(1)使用Admin账户登录后点击右上角头像,进入"Administration->Authentication->LDAPAuthentication"页面:(2)点击右上角的"Authenticationmode":三、参考1.官方ht......
  • 深入理解 DAO,DTO,DO,VO,AO,BO,POJO,PO,Entity,Model,View 各个模型对象的概念
    参考文档:https://blog.csdn.net/SR02020/article/details/105821816 深入理解DAO,DTO,DO,VO,AO,BO,POJO,PO,Entity,Model,View的概念DAO(DataAccessObject)数据访问对象DTO(DataTransferObject)数据传输对象DO(DomainObject)领域对象VO(ViewObject)视图模型AO(ApplicationObject)应用对象......
  • poj-2823 Sliding Window(单调队列)
    原题链接SlidingWindowTimeLimit: 12000MS MemoryLimit: 65536KTotalSubmissions: 54929 Accepted: 15814CaseTimeLimit: 5000MSDescriptionAnarrayofsize n ≤106 isgiventoyou.Thereisaslidingwindowofsize k whichismoving......
  • hdoj-5903 Square Distance
    原题链接SquareDistanceTimeLimit:4000/2000MS(Java/Others)    MemoryLimit:65536/65536K(Java/Others)TotalSubmission(s):245    AcceptedSubmission(s):83ProblemDescriptionAstringiscalledasquarestringifitcanbeobtainedbyconcatena......
  • BZOJ1461字符串的匹配
    题目具体思路与KMP板子很像;大致思路是将两个数字的排名来当字符比较用树状数组\(log_2(n)\)的复杂度来找排名。一定要注意边界问题具体实现思路可以看代码(PS:有奆佬说这题很板子,也许是我太弱了叭QAQ)//9:30开始写题,有些思路//40思路被pass,不会写了//55决定......
  • LC1171. 从链表中删去总和值为零的连续节点
    题目来源于力扣题库,题目链接:LC1171.从链表中删去总和值为零的连续节点Q:给你一个链表的头节点 head,请你编写代码,反复删去链表中由总和 值为0的连续节点组成的序列,直到不存在这样的序列为止。删除完毕后,请你返回最终结果链表的头节点。 你可以返回任何满足题目要求的答案。......
  • POJ 1459 Power Network(最大流)
    题意:第一眼看到这题目觉得神题啊...其实题目给的s[i]压根不用管的....总共有n个结点,其中有发电站np个、用户nc个和调度器n-np-nc个三种节点以及M条电线(用于传输电流的),每个发电站有一个最大发电量,每个用户有个最大接受电量,现在有m条有向边,边有一个最大的电流量,表示最多可以流出这......
  • POJ1787
    POJ1787一开始还没看多重背包…以为是完全背包加个限制条件,然后想了好久没想不出,看了下背包九讲..看到多重背包可是也没什么思路…后来搜了一下题解…豁然开朗dp[j]表示j块钱最多由多少块硬币组成,path[j]表示上一次最多有多少块构成的j块钱,used[j]表示j块钱时,已经放了......