C/C++ BM14 链表的奇偶重排

文章目录

  • 前言
  • 题目
  • 解决方案一
    • 1.1 思路阐述
    • 1.2 源码
  • 解决方案二
    • 2.1 思路阐述
    • 2.2 源码
  • 总结

前言

这道题算是链表思路的一种常规题,看透题目本质做起来还是不难。


题目

描述
给定一个单链表,请设定一个函数,将链表的奇数位节点和偶数位节点分别放在一起,重排后输出。
注意是节点的编号而非节点的数值。

数据范围:节点数量满足 0 ≤ n ≤ 1 0 5 0≤n≤10^5 0n105,节点中的值都满足 0 ≤ v a l ≤ 1000 0≤val≤1000 0val1000
要求:空间复杂度 O ( n ) O(n) O(n),时间复杂度 O ( n ) O(n) O(n)
示例1
输入:

{1,2,3,4,5,6}

返回值:

{1,3,5,2,4,6}

说明:

1->2->3->4->5->6->NULL
重排后为
1->3->5->2->4->6->NULL

示例2
输入:

{1,4,6,3,7}

返回值:

{1,6,7,4,3}

说明:

1->4->6->3->7->NULL
重排后为
1->6->7->4->3->NULL
奇数位节点有1,6,7,偶数位节点有4,3。重排后为1,6,7,4,3

解决方案一

1.1 思路阐述

题目要求的空间复杂度并没有限制为 O ( 1 ) O(1) O(1),所以可以考虑用一个辅助的链表来做。

因为最后的结果是把奇节点放一起再放偶节点,所以我可以把原来链表中所有的奇节点和偶节点都取出来,先取奇节点,再取偶节点,取出来的节点一次插入到辅助链表中去。

最后输出辅助链表对应的节点即可。

1.2 源码

/*** struct ListNode {*  int val;*  struct ListNode *next;*  ListNode(int x) : val(x), next(nullptr) {}* };*/
class Solution {public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param head ListNode类* @return ListNode类*/ListNode* oddEvenList(ListNode* head) {// write code hereListNode* newList = new ListNode(-1);ListNode* rec = newList;ListNode* tempHead = head;int count = 0;if (!head)return nullptr;while (head) {count++;//取奇数节点并插入if (count % 2 != 0) {ListNode* temp = new ListNode(head->val);rec->next = temp;rec = temp;head = head->next;} else {head = head->next;}}head=tempHead;count=0;//重置计数器后取偶数节点并插入while (head) {count++;//插入偶数if (count % 2 == 0) {ListNode* temp = new ListNode(head->val);rec->next = temp;rec = temp;head = head->next;} else {head = head->next;}}return newList->next;}
};

解决方案二

2.1 思路阐述

对于链表题的思路除了上面的开辟辅助链表(或者其他的辅助数组),通常还采用双指针来做。

如下图所示,第一个节点是奇数位,第二个节点是偶数,第二个节点后又是奇数位,因此可以断掉节点1和节点2之间的连接,指向节点2的后面即节点3,如红色箭头。如果此时我们将第一个节点指向第三个节点,就可以得到那么第三个节点后为偶数节点,因此我们又可以断掉节点2到节点3之间的连接,指向节点3后一个节点即节点4,如紫色箭头。那么我们再将第二个节点指向第四个节点,又回到刚刚到情况了。

在这里插入图片描述

2.2 源码

/*** struct ListNode {*	int val;*	struct ListNode *next;*	ListNode(int x) : val(x), next(nullptr) {}* };*/
class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param head ListNode类 * @return ListNode类*/ListNode* oddEvenList(ListNode* head) {if(!head)return nullptr;ListNode* odd=head;ListNode* even=head->next;ListNode*tempEven=even;while (even&&even->next) {odd->next=even->next;odd=odd->next;even->next=odd->next;even=even->next;}odd->next=tempEven;return head;}
};

总结

链表做题两种方式,双指针,开辟辅助数组或链表。

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

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

相关文章

电脑开机蓝屏错误代码c000021a怎么办 电脑蓝屏报错c000021a的解决办法

很多小伙伴在电脑开机的时候出现蓝屏代码c000021a都不知道该怎么去解决,所以今天就给你们带来了c000021a蓝屏解救方法,如果你还没解决的话就快来看看吧。 解决办法: 原因: c000021a蓝屏的原因有很多,主要有以下几种…

四非保研之旅

大家好,我是工藤学编程,虽有万分感概,但是话不多说,先直接进入正题,抒情环节最后再说,哈哈哈 写在开头 我的分享是来给大家涨信心的,网上的大佬们都太强了,大家拿我涨涨信心&#…

Spring Framework

Spring Framework Spring 是一款开源的轻量级 Java 开发框架,旨在提高开发人员的开发效率以及系统的可维护性。 Spring 框架指的都是 Spring Framework,它是很多模块的集合,如下图所示: 一、Core Container Spring 框架的核心模…

Samba是什么?有什么作用?工作流程以及如何搭建

前言: 寒假在家学习Linux近一个月了,最近参加了嘉立创组织的泰山派训练营,从中了解到了现在Linux开发中很方便的一些开发方式和工具。例如:使用MobaXterm终端通过SSH登陆ubuntu服务器进行开发;安装一个FileZilla工具通…

定制线缆厂家推荐:赋能科技互联,精工电联的集成线缆定制服务(小批量、多品类产品高效解决方案)

定制线缆 精工电联:赋能科技互联,精工电联的集成线缆定制服务(小批量、多品类产品高效解决方案) 随着科技的飞速发展,人们对数据传输速度和稳定性的需求日益增强。精工电联作为高科技智能化产品及自动化设备专用连接线…

第二证券:汽车产业链股爆发,中通客车涨停,星源卓镁等大涨

轿车产业链股21日盘中强势拉升,截至发稿,华阳变速涨超29%,星源卓镁涨超15%,德迈仕涨逾10%,中捷精工、中通客车、合力科技、圣龙股份等涨停。 行业方面,中国轿车工业协会近来公布数据显示,1月&a…

【快速搞定Webpack5】介绍及基本使用(一)

webpack 是一个静态资源打包工具。 他会以一个或多个文件作为打包的入口,将我们整个项目所有文件编译组合成一个或多个文件输出出去。 输出的文件就是编译好的文件,就可以在浏览器端运行了。 我们将 webpack 输出的文件叫做 bundle 。 (将浏览器不识别的…

wo-gradient-card是一款采用uniapp实现的透明辉光动画卡片

采用uniapp-vue3实现,透明辉光动画卡片,卡片内容包含标签、标题、副标题、图片 支持H5、微信小程序(其他小程序未测试过,可自行尝试) 可用于参考学习 可到插件市场下载尝试: https://ext.dcloud.net.cn/plu…

学习鸿蒙基础(5)

一、honmonyos的page路由界面的路径 新建了一个page,然后删除了。运行模拟器的时候报错了。提示找不到这个界面。原来是在路由界面没有删除这个page。新手刚接触找了半天才找到这个路由。在resources/base/profile/main_pages.json 这个和微信小程序好类似呀。 吐槽&#xf…

力扣精选算法100道——提莫攻击(模拟专题)

目录 🚩题目解析 🚩算法原理 🚩实现代码 🚩题目解析 输入:timeSeries [1,4], duration 2 输出:4 解释:提莫攻击对艾希的影响如下: - 第 1 秒,提莫攻击艾希并使其立即…

图片怎么转换格式jpg?轻松转换图片格式

图片怎么转换格式jpg?在数字化时代,图片作为信息传递的重要载体,其格式转换显得尤为重要。JPG作为一种广泛使用的图片格式,具有压缩比高、兼容性好等特点,深受用户喜爱。那么,如何将其他格式的图片轻松转换…

【41 Pandas+Pyecharts | 全国星巴克门店数据分析可视化】

文章目录 🏳️‍🌈 1. 导入模块🏳️‍🌈 2. Pandas数据处理2.1 读取数据2.2 查看数据信息2.3 计算营业时长2.4 营业时长区间 🏳️‍🌈 3. Pyecharts数据可视化3.1 各省星巴克门店数量柱状图3.2 各省星巴克门…

【力扣hot100】刷题笔记Day7

前言 身边同学已经陆陆续续回来啦,舍友都开始投简历了,我也要加油啦!刷完hot100就投! 73. 矩阵置零 - 力扣(LeetCode) 标记数组:空间复杂度O(mn) class Solution:def setZeroes(self, matrix:…

【日常聊聊】计算机专业必看的电影

🍎个人博客:个人主页 🏆个人专栏:日常聊聊 ⛳️ 功不唐捐,玉汝于成 目录 前言 正文 方向一:电影推荐 方向二:技术与主题 方向三:职业与人生 结语 我的其他博客 前言 计算机…

Linux环境安装Git(详细图文)

说明 此文档Linux环境为:Ubuntu 22.04,本文档介绍两种安装方式,一种是服务器能联网的情况通过yum或apt命令下载,第二种采用源码方式安装。 一、yum/apt方式安装 1.yum方式安装Git 如果你的服务器环境是centos/redhot&#xff…

最新Unity游戏主程进阶学习大纲(2个月)

过完年了,很多同学开始重新规划自己的职业方向,找更好的机会,准备升职或加薪。今天给那些工作了1~5年的开发者梳理”游戏开发客户端主程”的学习大纲,帮助大家做好面试准备。适合Unity客户端开发者。进阶主程其实就是从固定的几个方面搭建好完整的知识体…

HarmonyOS—@Observed装饰器和@ObjectLink嵌套类对象属性变化

Observed装饰器和ObjectLink装饰器:嵌套类对象属性变化 概述 ObjectLink和Observed类装饰器用于在涉及嵌套对象或数组的场景中进行双向数据同步: 被Observed装饰的类,可以被观察到属性的变化;子组件中ObjectLink装饰器装饰的状…

医卫医学生理学试题及答案,分享几个实用搜题和学习工具 #经验分享#知识分享

下面,我将为您介绍几款备受大学生欢迎的搜题软件,希望能够帮助您更好地完成学业和提升学习效果。 1.历史地图 历史地图app是一款学习型地图软件,历史地图app比较适用于对历史进行学习和偏爱历史的朋友使用 ,历史地图app支持多平…

Android Studio Hedgehog 代码补全失效问题记录

Android Studio Hedgehog 代码补全失效问题记录 代码失效问题网上答案很多,如: 关闭省电模式;清空缓存;重启电脑;删除重新安装啥的。但是很一行都没有用,并且我电脑上的4.3.3版本的Android Studio是没有该…

Rabbitmq入门与应用(六)-rabbitmq的消息确认机制

rabbitmq的消息确认机制 确认消息是否发送给交换机 配置 server:port: 11111 spring:rabbitmq:port: 5672host: 192.168.201.81username: adminpassword: 123publisher-confirm-type: correlated编码RabbitTemplate.ConfirmCallback ConfirmCallback 是一个回调接口&#xf…