LeetCode热题100—链表(二)

19.删除链表的倒数第N个节点

题目

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

示例 1:

img

输入:head = [1,2,3,4,5], n = 2
输出:[1,2,3,5]

示例 2:

输入:head = [1], n = 1
输出:[]

示例 3:

输入:head = [1,2], n = 1
输出:[1]

思路

这道题很明显要用双指针,因为捕获不到链表的长度,那么可以考虑快慢指针,让快指针先走n步,然后快慢指针同步进行,当快指针走到最后一个节点时,满指针正好是要删除指针的前面一项,此时进行slow->next = slow->next->next;即可,问题解决。

代码如下:

class Solution {
public:ListNode* removeNthFromEnd(ListNode* head, int n) {ListNode* first = head;ListNode* second = head;while(n--){second = second->next;}if(second == NULL){return head->next;}while(second->next != NULL){first = first->next;second = second->next;}first->next = first->next->next;return head;}
};

24.两两交换链表中的节点

题目

给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

示例 1:

img

输入:head = [1,2,3,4]
输出:[2,1,4,3]

示例 2:

输入:head = []
输出:[]

示例 3:

输入:head = [1]
输出:[1]

思路

肯定也是双指针,每次要移动两步,那么写个循环,如果下两个存在任何一个等于NULL,就跳出,记得前一个要写前面,那么就不会走||后面的判断,以及要记得最开始的特判,如果小于两个直接return head

代码如下:

class Solution {
public:ListNode* swapPairs(ListNode* head) {if(head == NULL || head->next == NULL)return head;ListNode* first = head; ListNode* second = head->next;while(1){int tmp = first->val;first->val = second->val;second->val = tmp;if(second->next == NULL || second->next->next == NULL)break;first = second->next;second = second->next->next;}return head;
​}
};

25.K个一组翻转链表

题目

给你链表的头节点 head ,每 k 个节点一组进行翻转,请你返回修改后的链表。

k 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序。

你不能只是单纯的改变节点内部的值,而是需要实际进行节点交换。

示例 1:

img

输入:head = [1,2,3,4,5], k = 2
输出:[2,1,4,3,5]

示例 2:

img

输入:head = [1,2,3,4,5], k = 3
输出:[3,2,1,4,5]

思路

可以考虑成一个栈,每k个就全入栈,然后依次弹出来并且接到后面,并且把下一次的开始继续保留下来继续更新,代码如下:

class Solution {
public:ListNode* reverseKGroup(ListNode* head, int k) {stack<ListNode*> stk;ListNode* dum = new ListNode();ListNode* p = dum;while(1){int count = k;ListNode* tmp = head;while(count && tmp){stk.push(tmp);tmp = tmp->next;count--;}if(count){  //如果此时不足k个,则直接退出,此时tmp为最后一个的下一个//head为前一组k个的下一个,此时直接接到后面即可p->next = head;break;}while(!stk.empty()){p->next = stk.top();stk.pop();p = p->next;}head = tmp;}return dum->next;

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

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

相关文章

SpringBoot的Profiles是什么

在 Spring Boot 中&#xff0c;Profiles 提供了一种隔离配置的方法&#xff0c;允许你定义多套配置&#xff0c;并且在不同的环境下激活不同的配置。例如&#xff0c;一个常见的用例是为开发、测试和生产环境提供不同的配置。 Profiles 可以帮助你在应用的不同运行环境之间切换…

Docker中搭建likeadmin

一、使用Docker中的docker-compose搭建likeadmin 1.去网址&#xff1a;https://gitee.com/likeadmin/likeadmin_php中下载likeadmin 注册一个giee账号后 点那个克隆下载 按照序号在终端复制粘贴进去。 接着&#xff0c;输入ls 可以发现有一个这个&#xff1a; 里面有一个like…

摄影店展示服务预约小程序的作用是什么

摄影店包含婚照、毕业照、写真、儿童照、工作照等多个服务项目&#xff0c;虽然如今人们手机打开便可随时拍照摄影&#xff0c;但在专业程度和场景应用方面&#xff0c;却是需要前往专业门店服务获取。 除了进店&#xff0c;也有外部预约及活动、同行合作等场景&#xff0c;重…

Ezsql(buuctf加固题)

开启环境 SSH连接 第一个为页面地址WEB服务 or 11# 利用万能密码登录 密码可以随便输入或者不输入 这里就可以判断这个题目是让我们加固这个登录页面 防止sql注入 查看index.php 添加以下代码 $username addslashes($username); $password addslashes($password);…

2024年京东618红包领取跨店满300减50第二波活动时间什么时候开始到几号结束?

2024年京东618活动时间 整个618红包满减活动时间是从&#xff1a;2024年5月28日12:00开始一直持续到6月20日23:59 第一波红包领取活动时间是从&#xff1a;2024年5月28日12:00开始到6月6日23:59结束 第二波红包领取活动时间是从&#xff1a;2024年6月7日00:00开始到6月18日2…

【HarmonyOS】放大缩小手势实现

【HarmonyOS】放大缩小手势实现 一、鸿蒙中手势的类型&#xff1a; 对于放大缩小手势&#xff0c;在应用开发中使用较为常见&#xff0c;例如预览图片时&#xff0c;扫码时等。 在鸿蒙中对于常见的手势进行的封装&#xff0c;可以通过简单的API进行监听调用&#xff0c;以下是…

springboot webflux 返回字节流

在Spring Boot WebFlux中&#xff0c;可以使用Mono<byte[]>或Flux<byte[]>作为响应体来返回字节流。以下是一个简单的示例&#xff1a; 1. 首先&#xff0c;添加WebFlux依赖到pom.xml文件中&#xff1a; xml <dependency> <groupId>org.springframewo…

k8s测试题

k8s集群k8s集群node01192.168.246.11k8s集群node02192.168.246.12k8s集群master 192.168.246.10 k8s集群nginxkeepalive负载均衡nginxkeepalive01&#xff08;master&#xff09;192.168.246.13负载均衡nginxkeepalive02&#xff08;backup&#xff09;192.168.246.14VIP 192…

【因果推断python】24_倾向得分2

目录 倾向加权 倾向得分估计 倾向加权 好的&#xff0c;我们得到了倾向得分。怎么办&#xff1f;就像我说过的&#xff0c;我们需要做的就是以此为条件。例如&#xff0c;我们可以运行一个线性回归&#xff0c;它仅以倾向得分为条件&#xff0c;而不是所有的 X。现在&#xff…

Spark 之 HiveStrategies

HiveTableRelation 相关代码 HiveStrategies.scala 当 relation.tableMeta.stats.isEmpty 是&#xff0c; 即调用 hiveTableWithStats class DetermineTableStats(session: SparkSession) extends Rule[LogicalPlan] {private def hiveTableWithStats(relation: HiveTableRel…

《微机原理及接口技术》

编程题&#xff1a; 编制一个程序片断&#xff0c;把保存在变量dataA和dataB中较大的数据取出后存入maxC。假设变量存放的是32位有符号数。 OV AX, DATA ; 段初始化 MOV DS, AX MOV AX, STACK MOV SS, AX MOV DX, WORD PTR BUFA2 ; 按题意&#xff0c;将数送入 DX,AX, BX,…

千问Qwen7B chat:简单代码使用

我们先用一个简单的例子看一下千问的代码逻辑及效果。 from modelscope import AutoModelForCausalLM, AutoTokenizer from modelscope import GenerationConfig# 加装分词 tokenizer AutoTokenizer.from_pretrained("qwen/Qwen-7B-Chat", revisionv1.0.5, trust_r…

每日一题36:数据分组之科目种类数量

一、每日一题 表: Teacher ------------------- | Column Name | Type | ------------------- | teacher_id | int | | subject_id | int | | dept_id | int | ------------------- 在 SQL 中&#xff0c;(subject_id, dept_id) 是该表的主键。 该表中的每一行都表示…

【postgresql初级使用】视图上的触发器instead of,替代计划的rewrite,实现不一样的审计日志

instead of 触发器 ​专栏内容&#xff1a; postgresql使用入门基础手写数据库toadb并发编程 个人主页&#xff1a;我的主页 管理社区&#xff1a;开源数据库 座右铭&#xff1a;天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物. 文章目录 inst…

Python私教张大鹏 Vue3整合AntDesignVue之Layout布局

案例&#xff1a;栅格布局 核心代码&#xff1a; <template><a-row><a-col :span"24">col</a-col></a-row><a-row><a-col :span"12">col-12</a-col><a-col :span"12">col-12</a-col…

国际货币基金组织警告:网络攻击影响全球金融稳定

近日&#xff0c;在一份关于金融稳定的报告中&#xff0c;国际货币基金组织&#xff08;IMF&#xff09;用了一章&#xff08;共三章&#xff09;的篇幅描述了网络攻击对金融环境的影响&#xff0c;并警告称&#xff0c;全球金融稳定正受到日益频繁和复杂的网络攻击的威胁。同时…

面试题react03

React事件机制&#xff1a; React的事件机制可以分为两个部分&#xff1a;事件的触发和事件的处理。事件的触发&#xff1a;在React中&#xff0c;事件可以通过用户与组件进行交互而触发&#xff0c;如点击、鼠标移动、键盘输入等。当用户与组件进行交互时&#xff0c;浏览器会…

Spring Security(二)OAuth2认证详解及自定义异常处理

1、OAuth2.0 简介 OAuth 2.0是用于授权的行业标准协议。OAuth 2.0为简化客户端开发提供了特定的授权流&#xff0c;包括Web应用、桌面应用、移动端应用等。 1.1 OAuth2.0 相关名词解释 Resource owner&#xff08;资源拥有者&#xff09;&#xff1a;拥有该资源的最终用户&…

每日题库:Huawe数通HCIA——14(30道)

所有资料均来源自网络&#xff0c;但个人亲测有效&#xff0c;特来分享&#xff0c;希望各位能拿到好成绩&#xff01; PS&#xff1a;别忘了一件三连哈&#xff01; 今日题库&#xff1a; 201. 如下图所示的网络&#xff0c;主机存在ARP缓存&#xff0c;主机A.发送数据包给…

Echarts 可视化图库案例(Make A Pie)

1、Made A Pie Made A Pie 2、可视化社区 &#xff08;Made A Pie 替代&#xff09; 可视化社区