LeetCode(2)合并链表、环形链表的约瑟夫问题、链表分割

一、合并链表

. - 力扣(LeetCode)

题目描述:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
typedef struct ListNode ListNode;
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {if (list1 == NULL){return list2;}if (list2 == NULL){return list1;}//如果list1开始是空,则返回list2,反之则返回list1;当两者都为空时,先走第一个if语句那么返回list2,list2为NULL。这样写包含了所有两者中有NULL的情况ListNode* newhead;ListNode* newtail;newhead = newtail = (ListNode*)malloc(sizeof(ListNode));if (newhead == NULL){perror("malloc fail!");exit(1);}//创建哨兵位ListNode* l1 = list1;ListNode* l2 = list2;while (l1 && l2){if (l1->val < l2->val){newtail->next = l1;newtail = newtail->next;l1 = l1->next;}else{newtail->next = l2;newtail = newtail->next;l2 = l2->next;}}//从l1、l2开始遍历,比较相应的val值,哪个小就把这个小的节点往哨兵位后面尾插if (l2){newtail->next = l2;}if (l1){newtail->next = l1;}//遍历两个链表时,会有一方先为空,另外一个不为空的的剩余的节点的val值都比新链表里面的小,并且list1、2都是升序,所以此时直接把没有插完的剩余的链表尾插到新链表的尾节点后面ListNode* rsl = newhead->next;free(newhead);newhead = NULL;return rsl;//动态开辟的空间要释放,但是也要依靠这个开辟的节点来返回,所以定义一个临时节点,释放完开辟的节点,将这个临时节点作为返回值。
}

 

二、环形链表的约瑟夫问题

环形链表的约瑟夫问题_牛客题霸_牛客网

/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param n int整型 * @param m int整型 * @return int整型*/
typedef struct ListNode ListNode;
//申请节点
ListNode* BuyNode(int x)
{ListNode* newnode=(ListNode*)malloc(sizeof(ListNode));if(newnode==NULL){exit(1);}newnode->next=NULL;newnode->val=x;return newnode;
}
#include <stdarg.h>
int ysf(int n, int m ) {// write code hereListNode* tail;ListNode* head;tail=head=(ListNode*)malloc(sizeof(ListNode));if(head==NULL){exit(1);}head->next=NULL;head->val=1;//设置头节点(1<=n)for(int i=2;i<=n;i++){ListNode* newnode=BuyNode(i);tail->next=newnode;tail=tail->next;}//创建一个链表//创建环形链表tail->next=head;ListNode* pcur=head;ListNode* prev=tail;int count=1;while(pcur->next!=pcur){if(count!=m){pcur=pcur->next;prev=prev->next;count++;}else{prev->next=pcur->next;free(pcur);pcur=prev->next;count=1;}}return pcur->val;
}

while循环内部解释:假设n=5,m=2;最开始让pcur指向val为1的节点,让prev指向val为5的节点,设置一个计数器count,让其最开始的默认值是1;用count来记录pcur的走的步数(也就是报数为几),m为2,则先走if语句,此时pcur和prev都往后走一步,pcur指向2,prev指向1,count变为2(报数为2)要开始删除数据;则第二次循环进入else语句:开始删除数据,但是为了找到之后的链表节点,先让prev的next指针指向pcur的next指向的节点,再删除pcur(此时是2,符合题意,报数为2的删除)再让pcur为prev->next

此时prev的val为1,pcur的val为3,count重置为1(与题中当删除数据之后要从这个被删除数据的下一个数据重新开始计数);此时循环进入if语句,count变为2(正常报数),prev的val为3,pcur的val为4;再一次循环进入else语句,开始删除数据让prev的next指向pcur的next(也就是val为5的节点),再删除pcur(val为4的节点),让pcur为prev的next;此时pcur的val为5,prev的val为3,count重置为1;

依次类推;最后只剩下val为3的节点,并且此时pcur的next指向的就是它自己,返回这个val值就是最终结果。


三、分割链表

. - 力扣(LeetCode)

 

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
struct ListNode* partition(struct ListNode* head, int x)
{if(head==NULL){return NULL;}ListNode* lesshead;ListNode* lesstail;lesshead=lesstail=(ListNode*)malloc(sizeof(ListNode));ListNode* morehead;ListNode* moretail;morehead=moretail=(ListNode*)malloc(sizeof(ListNode));if(lesshead==NULL || morehead==NULL){exit(1);}ListNode* pcur=head;while(pcur){if(pcur->val<x){lesstail->next=pcur;lesstail=lesstail->next;}else{moretail->next=pcur;moretail=moretail->next;}pcur=pcur->next;}moretail->next=NULL;lesstail->next=morehead->next;ListNode* rsl=lesshead->next;free(morehead);free(lesshead);morehead=NULL;lesshead=NULL;return rsl;
}

 思路:创造两个新的链表,一个存储val比x小的节点,一个存储val比x大的节点,遍历原链表根据val的大小对新的两个链表进行尾插;结束之后要把这两个链表连起来,让存储较小值的链表在前面,但是这个链表不包含哨兵位,所以要让  lesstail->next=morehead->next;  最终释放这两个动态开辟的节点,返回合并链表的头节点。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/44378.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++入门基础篇(下)

目录 6.引用 6.1 引用的特性 6.2 const引用 7.指针和引用的关系 8.内联函数 9.nullptr 6.引用 引⽤不是新定义⼀个变量&#xff0c;⽽是给已存在变量取了⼀个别名&#xff0c;编译器不会为引⽤变量开辟内存空间&#xff0c; 它和它引⽤的变量共⽤同⼀块内存空间。比如&a…

【Vue3】使用vite创建vue项目

一、安装Nodejs 参考文章https://blog.csdn.net/DX390609/article/details/140305585?spm1001.2014.3001.5502 二、创建项目 在要创建的目录下打开命令行输入&#xff1a; npm create vuelatestvue项目创建成功&#xff1a; 三、安装vue插件 vscode打开项目文件夹&…

谷歌个人开发者账号14天封测审核通过技巧,你还不知道吗?

众所周知&#xff0c;目前在Google play应用商店上架应用已经不是那么容易了&#xff0c;谷歌各种政策的更新以及审核系统的升级&#xff0c;给开发者们带来了不少挑战。 尤其针对个人开发者账号需要20人连续14天的封测的要求&#xff0c;周期长&#xff0c;且随着政策执行力度…

31_JQuery一文读懂,JS的升级版

今日内容 零、 复习昨日 一、JQuery 零、 复习昨日 1 js数组的特点(长度,类型,方法) - js数组的长度不限 - 类型不限 - 提供很多方法2 js中和的区别 - 判断数值相等 - 判断数值和数据类型同时相等3 js表单事件的事件名(事件属性单词) - 获得焦点 onfocus - 失去焦点 onblur …

Qt开发 | Qt模型视图代理(Model-View-Delegate)

文章目录 一、Qt MVD概念讲解二、Qt模型视图代理之&#xff1a;QTableView的使用三、Qt模型视图代理之&#xff1a;QListView的使用 一、Qt MVD概念讲解 Qt MVD&#xff08;Model-View-Delegate&#xff09;是Qt框架中的一种设计模式&#xff0c;是Qt中用界面组件显示与编辑数据…

深入解析C++11:现代特性和应用

目录 一.c11.简介二.列表初始化和initializer_list1.列表初始化2.initializer_list 三.简化声明1.auto2.decltype 四.新增容器1.array2.forward_list3.unordered_map/set 五.右值引用与移动语义1.左值和右值2.左值引用3.右值引用4.移动构造和移动赋值5.万能引用和引用折叠6.完美…

git-工作场景

1. 远程分支为准 强制切换到远程分支并忽略本地未提交的修改 git fetch origin # 获取最新的远程分支信息 git reset --hard origin/feature_server_env_debug_20240604 # 强制切换到远程分支&#xff0c;并忽略本地修改 2. 切换分支 1. **查看所有分支&#xff1a;**…

mount卡住(失败)解决方案

mount -a卡主 第一步确保两边都打开了NFS服务&#xff01;&#xff01;&#xff01;&#xff01; 客户端执行mount -av 查看信息是拒绝服务 查看服务端&#xff1a;showmount -e 192.168.25.168 看提示信息处理&#xff0c;关闭两端的防火钱 遇到这个错误就是服务端不让客户端…

JAVA--SpringCloud

SpringCloud基础 为什么需要spring cloud 单体结构--Monolith 首先请回想一下我们所开发的服务是什么样子的。通常情况下&#xff0c;这个服务所对应的代码由多个项目&#xff08;模块&#xff09;所组成&#xff0c;各个项目会根据自身所提供功能的不同具有一个明确的边界。…

C++类与对象-基础篇

目录 一、什么是类 1.1 语法定义 1.2 访问限定符 1.3 类域 二、类的实例化 2.1 什么是实例化 2.2 类的大小 三、this指针 3.1 引入 3.2 this指针的使用 一、什么是类 1.1 语法定义 class 类名 {}; 说明 类似于C语言中的结构体&#xff0c;括号后分号不能丢类内成员可…

算术运算符用途解析及应用案例

文章目录 常用的算术运算符及其用途&#xff1a;运算符优先级类型转换高级用法 应用案例1. 计算器程序2. 平方根计算3. 计算平均数和标准差4. 货币兑换5. 计算几何6. 动力学模拟7. 数字图像处理8. 金融计算&#xff1a;复利计算 常用的算术运算符及其用途&#xff1a; 算术运算…

前端面试题40(浅谈MVVM双向数据绑定)

MVVM&#xff08;Model-View-ViewModel&#xff09;架构模式是一种用于简化用户界面&#xff08;UI&#xff09;开发的软件架构设计模式&#xff0c;尤其在现代前端开发中非常流行&#xff0c;例如在使用Angular、React、Vue.js等框架时。MVVM模式源于经典的MVC&#xff08;Mod…

软件架构之软件架构概述及质量属性

软件架构之软件架构概述及质量属性 第 9 章&#xff1a;软件架构设计9.1 软件架构概述9.1.1 软件架构的定义9.1.2 软件架构的重要性9.1.3 架构的模型 9.2 架构需求与软件质量属性9.2.1 软件质量属性9.2.2 6 个质量属性及实现 第 9 章&#xff1a;软件架构设计 像学写文章一样&…

前后端如何实现非对称加解密-使用RSA为例讲解!

写在最前面&#xff0c;RSA是一种非对称加密算法&#xff0c;使用不同的公钥和私钥进行加密和解密。 下面是使用RSA进行加密和解密的代码示例&#xff1a; 前端&#xff1a;使用CryptoJS进行RSA加密 在前端JavaScript中&#xff0c;使用jsencrypt库来进行RSA加密&#xff1a…

领夹麦克风哪个品牌好,哪个麦克风好,热门无线麦克风品牌推荐

​无线领夹麦克风是现代沟通的重要工具&#xff0c;它不仅提高了语音交流的清晰度&#xff0c;还展现了使用者的专业形象。随着技术发展&#xff0c;这些麦克风已经变得更加轻便、时尚&#xff0c;易于使用。在各种场合&#xff0c;如演讲、教育和网络直播中&#xff0c;当然&a…

Matplotlib入门

#折线图用来表示数据的变化 plt.plot(x,y) #直方图用来统计连续性数据 无间隔 plt.hist(data数组,组数) #条形图用来统计离散的数组 并且反映其变化 有间隔 plt.bar(x,y,width 0.3) plt.barh(y,x,height 0.3) #散点图用来xy轴之间的联系 趋势 plt.scatter(x,y) #导入p…

重命名文件的方法有哪些?重命名文件的工具有哪些?

在日常的计算机使用过程中&#xff0c;重命名文件是一项常见但至关重要的任务。无论是为了更好地组织文件、修复命名错误&#xff0c;还是简化文件管理流程&#xff0c;掌握正确的重命名方法和工具都能显著提升效率。 本文将探讨多种重命名文件的方法&#xff0c;同时介绍几款高…

解决Invalid or unsupported by client SCRAM mechanisms(dbeaver)

在用工具&#xff08;dbeaver&#xff09;链接Opengauss数据库的时候&#xff0c;报出标题的错误。原因为驱动不正确。 驱动下载地址&#xff1a;https://opengauss.org/zh/download/ 下载完的包 &#xff0c;解压后&#xff0c;里面应该有两个jar 包,使用postgresql.jar dbe…

国产大模型第一梯队玩家,为什么pick了CPU?

AI一天&#xff0c;人间一年。 现在不论是大模型本身&#xff0c;亦或是AI应用的更新速度简直令人直呼跟不上—— Sora、Suno、Udio、Luma……重磅应用一个接一个问世。 也正如来自InfoQ的调查数据显示的那般&#xff0c;虽然AIGC目前还处于起步阶段&#xff0c;但市场规模已…

qmt量化交易策略小白学习笔记第55期【qmt编程之期权数据--获取历史期权列表】

qmt编程之获取期权数据 qmt更加详细的教程方法&#xff0c;会持续慢慢梳理。 也可找寻博主的历史文章&#xff0c;搜索关键词查看解决方案 &#xff01; 感谢关注&#xff0c;咨询免费开通量化回测与获取实盘权限&#xff0c;欢迎和博主联系&#xff01; 获取历史期权列表 …