首页 > 编程语言 >单向链表题库2(c++)

单向链表题库2(c++)

时间:2024-11-14 15:18:45浏览次数:3  
标签:head ListNode val int c++ next 链表 题库

目录

前言

接着上一个作品的题库,没学单向链表的先看我这个作品(蓝色字体点进去),再看题库1巩固知识,然后再看这个题库。

在这里插入图片描述

1.力扣——LCR 123. 图书整理 I

(蓝色字体点进去看原题)

代码题解

/**
 * Definition for singly-linked list.
 * 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) {}
 * };
 */
class Solution {
public:
    vector<int> reverseBookList(ListNode* head) {//这一题就是反转链表,也就是逆序输出链表
        vector<int> ans;//定义一个顺序表用于返回逆序输出的值
        while(head){
            ans.push_back(head->val);
            head=head->next;
        }
        int l=0,r=ans.size()-1;//一定要注意顺序表是从下标0开始的所以最后一个下标是长度减一
        while(l<r){//逆序输出就相当于对称换值
            int t=ans[l];
            ans[l]=ans[r];
            ans[r]=t;
            l++,r--;//l往后跑,r往前跑
        }
        return ans;
    }
};

2.力扣——LCR 024. 反转链表

代码题解

/**
 * Definition for singly-linked list.
 * 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) {}
 * };
 */
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        if(!head||!head->next)return head;//递归出口,如果链表头结点为空或者只有一个节点就返回head
        ListNode*newHead=reverseList(head->next);//newHead用于每层反转链表之后的新头节点
        head->next->next=head;//反转链表以后head就不是头结点了是尾结点head->next看做newHead,newhead->next为head
        head->next=NULL;//因为head为尾结点所以head->next为空
        return newHead;
    }
};

3.力扣LCR 141. 训练计划 III

/**
 * Definition for singly-linked list.
 * 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) {}
 * };
 */
class Solution {
public:
    ListNode* trainningPlan(ListNode* head) {
        if(!head||!head->next) return head;
        ListNode*newHead=trainningPlan(head->next);
        head->next->next=head;
        head->next=NULL;
        return newHead;
    }
};

4.力扣——2487. 从链表中移除节点

/**
 * Definition for singly-linked list.
 * 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) {}
 * };
 */
class Solution {
public:
    ListNode* removeNodes(ListNode* head) {
        if(!head)return NULL;//递归出口
        head->next=removeNodes(head->next);//假定进行递归的时候得到一个单调不增的链表,返回这个链表的头结点
        if(head->next==NULL)return head;//然后让head与head->next(单调不增的链表头结点)比较如果head大返回head,反之返回head->next也就是移除了head
        if(head->val<head->next->val)return head->next;
        return head;
    }
};

5.力扣——2816. 翻倍以链表形式表示的数字

/**
 * Definition for singly-linked list.
 * 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) {}
 * };
 */
class Solution {
    void doDouble(ListNode*head,int* cap){//cap代表进位的值
        if(!head){//递归出口head为空也就是链表到尾部了
            *cap=0;//最后一位的进位肯定为0
            return ;
        }
        int val;
        doDouble(head->next,&val);
        *cap=(2*head->val+val)/10;//记录当前节点的进位        
        head->val=(2*head->val+val)%10;//记录当前节点翻倍后的值
    }
public:
    ListNode* doubleIt(ListNode* head) {
        int val;
        doDouble(head,&val);
        return val == 0 ? head : (new ListNode(val,head));//如果val为0也就是说最高位没有进位也就不用生成新的节点,否则生成新的节点保留进位的值返回即可
    }
};

结语

看完这几题,如果你还想刷更多有关单向链表的题,就去力扣题库分类查看数据结构单向链表的题,那么单向链表就告一段落了,下一个作品我会讲初级数据结构——栈。

在这里插入图片描述

想看更多内容可以关注我,看我作品,关注我让我们一起学习编程,希望大家能点赞关注支持一下,让我有持续更新的动力,谢谢大家
在这里插入图片描述

标签:head,ListNode,val,int,c++,next,链表,题库
From: https://blog.csdn.net/ycs66/article/details/143734071

相关文章

  • c++ 标准 智能指针 与 qt 智能指针 对比
    C++标准库提供了std::unique_ptr和std::shared_ptr等智能指针,而Qt则提供了QScopedPointer、QSharedPointer和QWeakPointer等自己的智能指针。两者在设计上有一些相似之处,但也存在一些关键的差异。下面是C++标准智能指针和Qt智能指针的详细对比:1.std::uniq......
  • C++生成随机数
    目录一、传统方式:std::rand 和 std::srand使用方法:优缺点:二、现代方式: 库(推荐)1. 随机整数2. 随机浮点数3. 布尔值4. 字符5. 正态分布(高斯分布)6. 离散分布的随机数7. 随机字符串8. UUID(通用唯一标识符)三、std::shuffle:用于打乱序列四、总结:选择合适的......
  • 【华为OD机试真题E卷】573、区间交叠问题 | 机试真题+思路参考+代码解析(E卷复用)(C++、J
    文章目录一、题目......
  • Linux-vscode-c++-slambook2-库文件找不到路径
    Linux-vscode-c++-slambook2-库文件找不到路径分享所遇到的困难,填补这些坑洞,希望后来者能够如履平地。首先已经在c_cpp_properties.json中已经添加了相关的文件,"includePath":["${workspaceFolder}/**","/usr/include/eigen3"......
  • 三步解决error: Microsoft Visual C++ 14.0 or greater is required. Get it with “M
    文章目录前言一、问题描述二、报错信息三、解决步骤1.下载并安装MicrosoftVisualC++BuildTools2.配置系统环境变量3.重新运行安装指令四、安装成功总结前言本文记录了在使用AnacondaPrompt安装Python程序包时遇到的报错问题,并详细描述了如何通过安装Micros......
  • c++类循环依赖的问题
    目前的一种状况是A类中以B类指针作为成员变量,B类在构造时需传入A类指针作为参数。a.hclassA{ B*b;};b.hclassB{ B(A*a);};这种情况需要在头文件中前向声明,然后在.cpp文件中include另一个类的头文件。如下:a.hclassB;classA{ B*b;};b.hclassA;classB{ B......
  • C++中的方法宏定义
    #defineCORE_INIT(fn)__define_core_initcall(fn)这一行代码是一个宏定义,用于将fn传递给__define_core_initcall宏或函数。具体解释如下:#define:定义一个宏,用于将宏名替换为对应的代码片段。CORE_INIT(fn):这是宏的名称和参数。CORE_INIT是宏名,fn是参数,表示函数或代......
  • C++基础语法实现写时复制CowString
    前言: CowString写时复制设计思路难点:通过下标访问字符串元素的基本思路重载[]运算符,在函数中直接返回该位置指针的解引用,但此时返回值为char类型,对于进行单个字符串修改的操作,如:str[1]='H';,无法处理赋值时的写时复制操作,只能通过输出流运算符输出char。解决方法:可以在Cow......
  • C++单例模式实现
    单例模式(SingletonPattern)是软件设计模式中的一种,用于确保一个类只有一个实例,并提供一个全局访问点来获取这个实例。一、初始版本(手动创建释放)一个类只有一个实例的实现方法:隐藏构造函数,是外界无法创造对象通过类静态成员函数getInstance返回静态局部对象指针(指向堆空间的......
  • C++ 左值引用和右值引用之间的转换
    intretVal(int&&v){cout<<"右值引用:";returnv;}intretVal(int&v){cout<<"左值引用:";returnv;}intretVal(constint&v){cout<<"const左值引用:";returnv;}i......