当前位置: 首页 > news >正文

菜鸟刷题Day6

⭐作者:别动我的饭
⭐专栏:菜鸟刷题
⭐标语:悟已往之不谏,知来者之可追
在这里插入图片描述

一.链表内指定区间反转:链表内指定区间反转_牛客题霸_牛客网 (nowcoder.com)

描述

将一个节点数为 size 链表 m 位置到 n 位置之间的区间反转,要求时间复杂度 O(n),空间复杂度O(1)
例如:给出的链表为1→2→3→4→5→NULL m=2,n=4,
返回 1→4→3→2→5→NULL


解题思路

如果只有一个节点或者m==n,那就直接返回head,因为不用反转。如果有多个节点,那就需要建立一个哨兵位标记住头节点,后续需要移动头节点。然后找到反转位置的前驱节点,再将反转位置赋值给head,将m到n之间的节点取下来头插就可以达到反转链表的效果。(head会随着不断头插向后挪动,需要用一个next指针记住head的下一个节点),此外要注意好区间范围的控制。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZB1Dlp1l-1679744040656)(C:\Users\羽北冥\AppData\Roaming\Typora\typora-user-images\image-20230325131417710.png)]

struct ListNode* reverseBetween(struct ListNode* head, int m, int n ) {// write code here//如果只有一个节点或者没有节点就直接返回if(head==NULL||head->next==NULL||m==n)return head;//如果有多个节点,就建立一个哨兵位节点,找到反转位置拿下来头插struct ListNode*tmp=(struct ListNode*)malloc(sizeof(struct ListNode));tmp->next=head;struct ListNode*prev=tmp;for(int i=1;i<m;i++){prev=prev->next;}//将需要反转链表的头部搞给headhead=prev->next;for(int j=m;j<n;j++){//将节点取下来头插struct ListNode*next=head->next;head->next=next->next;next->next=prev->next;prev->next=next;}head=tmp->next;free(tmp);
return head;}

二.从链表中删去总和值为零的连续节点:1171. 从链表中删去总和值为零的连续节点 - 力扣(LeetCode)

描述

给你一个链表的头节点 head,请你编写代码,反复删去链表中由 总和 值为 0 的连续节点组成的序列,直到不存在这样的序列为止。

删除完毕后,请你返回最终结果链表的头节点。

你可以返回任何满足题目要求的答案(注意,下面示例中的所有序列,都是对 ListNode 对象序列化的表示。)

示例 1:

输入:head = [1,2,-3,3,1]
输出:[3,1]
提示:答案 [1,2,1] 也是正确的。

解题思路

首先要明确一点:这个数组不是绝对有序的(因为我当时考虑了哈哈)。

核心就是只要前面的数值相加结果等于零,那么前面所有的节点都可以舍弃。但是你直接从零位置开始累加的话不一定会得到前缀和能为零,所以这里可以考虑使用嵌套循环,也就是说如果从第一个位置累加不能为零,那么就从第二个位置再累加一次。直接走完所有的节点都不能累加为零,就说明所有的数都是正数。

struct ListNode* removeZeroSumSublists(struct ListNode* head){struct ListNode*phead=(struct ListNode*)malloc(sizeof(struct ListNode));phead->next=head;//用双指针嵌套循环struct ListNode*cur=phead;struct ListNode*curr=cur->next;int sum=0;while(cur){sum=0;//这里必须在更新一下保证第二次循环不被影响curr=cur->next;//这里怎么能不更新currwhile(curr){sum+=curr->val;if(sum==0){cur->next=curr->next;//不释放节点,直接更新cur位置       }curr=curr->next;}cur=cur->next;}return phead->next;
}

三.链表求和:面试题 02.05. 链表求和 - 力扣(LeetCode)

描述

给定两个用链表表示的整数,每个节点包含一个数位。这些数位是反向存放的,也就是个位排在链表首部。编写函数对这两个整数求和,并用链表形式返回结果。

示例:

输入:(7 -> 1 -> 6) + (5 -> 9 -> 2),即617 + 295
输出:2 -> 1 -> 9,即912

解题思路

我最开始想着设定两个变量然后分别循环遍历两个链表,将两个链表中得到的值存储给变量n1,n2,最后两者相加得到sum,再对sum做文章。但是这样要走两次循环,后面我有思考了一下发现可以直接相加。

除n1和n2以外,在设定一个carry变量用来保存进位(对于加法来说如果这两个数相加大于十,则要往前进一位,再将这一位加给十位相加得到的结果),可以直接将这三个变量相加的结果存放到链表中。需要注意的是链表最后的节点相加可能超过十,所以出了循环以后要对carry判断一下,如果carry不为零,则还要开一个节点存放carry

此外设置一个head和一个tail指针,在第一次插入的时候初始化head,后续只动tail指针,最后用head做返回值。

struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2)
{int n1,n2=0;int carry=0,sum=0;struct ListNode*head=NULL,*tail=NULL;while(l1||l2)//如果两个都是空就没有意义了{n1=l1?l1->val:0;//如果l1不是空,就返回它的值否则返回0n2=l2?l2->val:0;sum=n1+n2+carry;if(head==NULL){head=tail=(struct ListNode*)malloc(sizeof(struct ListNode));tail->val=sum%10;//sum的值可能超过十,我们只需要存sum的个位就行tail->next=NULL;}else{//不是第一次插入,只动尾节点tail->next=(struct ListNode*)malloc(sizeof(struct ListNode));tail->next->val=sum%10;tail=tail->next;tail->next=NULL;}carry=sum/10;//更新carry//如果了l1和l2不为空就继续往下走if(l1)l1=l1->next;if(l2)l2=l2->next;}if(carry>0){tail->next=(struct ListNode*)malloc(sizeof(struct ListNode));tail->next->val=carry;tail->next->next=NULL;}
return head;
}

四.括号的最大嵌套深度:1614. 括号的最大嵌套深度 - 力扣(LeetCode)

描述

如果字符串满足以下条件之一,则可以称之为 有效括号字符串(valid parentheses string,可以简写为 VPS):

字符串是一个空字符串 “”,或者是一个不为 “(” 或 “)” 的单字符。
字符串可以写为 AB(A 与 B 字符串连接),其中 A 和 B 都是 有效括号字符串 。
字符串可以写为 (A),其中 A 是一个 有效括号字符串 。
类似地,可以定义任何有效括号字符串 S 的 嵌套深度 depth(S):

depth(“”) = 0
depth© = 0,其中 C 是单个字符的字符串,且该字符不是 “(” 或者 “)”
depth(A + B) = max(depth(A), depth(B)),其中 A 和 B 都是 有效括号字符串
depth(“(” + A + “)”) = 1 + depth(A),其中 A 是一个 有效括号字符串
例如:“”、“()()”、“()(()())” 都是 有效括号字符串(嵌套深度分别为 0、1、2),而 “)(” 、“(()” 都不是 有效括号字符串 。

给你一个 有效括号字符串 s,返回该字符串的 s 嵌套深度 。

示例 1:

输入:s = "(1+(2*3)+((8)/4))+1"
输出:3
解释:数字 8 在嵌套的 3 层括号中。

解题思路

这类题目用栈会比较好处理,但是C语言如果要使用栈的话,又要徒手写一个,这样太耗费时间了。所以这里可以采用一个数组通过下标的控制来达到模拟栈的效果。

如果是左括号就将其入栈,如果是右括号就将左括号出栈。也就是说如果是 “( ”则size–,如果是 “ )”则size++,以此来表示栈内容量的变化。在不断入栈出栈的过程中,size的最大值就是括号的最大嵌套深度,因为s是一个有效的括号字符串。

#define MAX(a,b) ((a)>(b)?(a):(b))int maxDepth(char * s)
{int len=strlen(s);int size=0;for(int i=0;i<len;i++){if(s[i]=="(")size++;ans=MAX(size,ans);if(s[i]==")")size--;}return ans;
}

其实就是拥有左括号数的最大值


最近铃芽之旅上线了不知道各位有没有去看(又有多少老铁是一个人去看的,斜眼笑),昨天我可是特意给你们放了假(好吧,其实是昨天课太多了,而我又被某些题目卡了三个小时所以才没来得及,菜鸡流泪)。

人们总是高估短期努力能够带来的提升,却忽略长期坚持能带来的改变。今天是第六天了,你还有坚持吗?

相关文章:

菜鸟刷题Day6

⭐作者&#xff1a;别动我的饭 ⭐专栏&#xff1a;菜鸟刷题 ⭐标语&#xff1a;悟已往之不谏&#xff0c;知来者之可追 一.链表内指定区间反转&#xff1a;链表内指定区间反转_牛客题霸_牛客网 (nowcoder.com) 描述 将一个节点数为 size 链表 m 位置到 n 位置之间的区间反转…...

DecimalFormat格式化显示数字

DecimalFormat 是 NumberFormat 的一个具体子类&#xff0c;用于格式化十进制数字&#xff0c;可以实现以最快的速度将数字格式化为你需要的样子。 DecimalFormat 类主要靠 # 和 0 两种占位符号来指定数字长度。0 表示如果位数不足则以 0 填充&#xff0c; # 表示只要有可能就…...

cpu中缓存简介

一级缓存是什么&#xff1a; 一级缓存都内置在CPU内部并与CPU同速运行&#xff0c;可以有效的提高CPU的运行效率。一级缓存越大&#xff0c;CPU的运行效率越高&#xff0c;但受到CPU内部结构的限制&#xff0c;一级缓存的容量都很小。 CPU缓存&#xff08;Cache Memory&#xf…...

【数据结构】二叉树的遍历以及基本操作

目录 1.树形结构 1.概念 2.二叉树 2.1概念 2.2 两种特殊的二叉树 2.3二叉树的存储 2.4二叉树的基本操作 1.手动快速创建一棵简单的二叉树 2.二叉树的遍历 (递归) 3.二叉树的层序遍历 4.获取树中节点的个数 5.获取叶子节点的个数 6.获取第K层节点的个数 7.获取二叉…...

若依框架 --- ruoyi 表格的设置

表格 字典值转换 (1) 方式1&#xff1a;使用字典枚举的方式 var isDownload [[${dict.getType(YES_OR_NO)}]];{field : isDownload,title : 是否允许下载,formatter: function(value, row, index) {return $.table.selectDictLabel(isDownload, value);} }, (2) 方式2&…...

“两会”网络安全相关建议提案回顾

作为新一年的政治、经济、社会等发展的“风向标”&#xff0c;今年“两会”在3月13日顺利闭幕。在今年“两会”期间&#xff0c;多位人大代表也纷纷围绕网络安全、数据安全的未来发展做了提案和建议。 01 “两会”网络安全相关建议和提案回顾 建议统筹智能网联汽车数据收集与共…...

一篇文章带你真正了解接口测试(附视频教程+面试真题)

目录 一、什么是接口测试&#xff1f; 二、为什么要做接口测试&#xff1f; 三、如何开展接口测试&#xff1f; 四、接口测试常见面试题 一、什么是接口测试&#xff1f; 所谓接口&#xff0c;是指同一个系统中模块与模块间的数据传递接口、前后端交互、跨系统跨平台跨数据…...

C/C++每日一练(20230325)

目录 1. 搜索插入位置 &#x1f31f; 2. 结合两个字符串 &#x1f31f; 3. 同构字符串 &#x1f31f; &#x1f31f; 每日一练刷题专栏 &#x1f31f; Golang每日一练 专栏 Python每日一练 专栏 C/C每日一练 专栏 Java每日一练 专栏 1. 搜索插入位置 给定一个排序数…...

Linux操作系统ARM指令集与汇编语言程序设计

一、实验目的1.了解并掌握ARM汇编指令集2.应用ARM指令集编写一个程序操控开发板上的LED灯二、实验要求应用ARM汇编指令集编写程序&#xff0c;实现正常状态下开发板上的LED灯不亮&#xff0c;按下一个按键之后开发板上的LED灯进入流水灯模式。三、实验原理四个LED灯的电路如下图…...

计网之HTTP协议和Fiddler的使用

文章目录一. HTTP概述和fidder的使用1. 什么是HTTP2. 抓包工具fidder的使用2.1 注意事项2.2 fidder的使用二. HTTP协议格式1. HTTP请求格式1.1 基本格式1.2 认识URL1.3 方法2. 请求报头关键字段3. HTTP响应格式3.1 基本格式3.2 状态码一. HTTP概述和fidder的使用 1. 什么是HTT…...

sql性能优化:MS-SQL(SQL Server)跟踪日志信息结果列字段说明,MSSQL的列字段说明(column)

sql性能优化&#xff1a;MS-SQL&#xff08;SQL Server&#xff09;跟踪日志信息结果列字段说明&#xff0c;MSSQL的列字段说明&#xff08;column&#xff09; 参考&#xff1a; SQL:BatchCompleted 事件类 | Microsoft Learn SQL 跟踪 | Microsoft Learn sp_trace_setevent (…...

DNS主从复制

#前提准备&#xff1a;关闭SElinux 关闭防火墙 时间同步 #环境说明&#xff1a;Centos7 #ip地址&#xff1a;dns-master&#xff1a;10.0.0.100 dns-slave&#xff1a;10.0.0.103 web&#xff1a;10.0.0.101 主DNS服务配置 1.安装软件包&#xff1a; yum install bind -…...

常见的js加密/js解密方法

常见的js加密/js解密方法 当今互联网世界中&#xff0c;数据安全是至关重要的。为了保护用户的隐私和保密信息&#xff0c;开发人员必须采取适当的安全措施。在前端开发中&#xff0c;加密和解密技术是一种常见的数据安全措施&#xff0c;其中 JavaScript 是最常用的语言之一。…...

6 python函数

函数 在实现某个功能对应的代码的时候&#xff0c;如果将实现功能对应的函数放到函数中&#xff0c;那么下一次再需要这个功能的时候&#xff0c;就可以不用再写这个功能对应的代码&#xff0c;直接调用这个功能对应的函数。 1.什么是函数 函数就是实现某一特点功能的代码的封装…...

7.避免不必要的渲染

目录 1 组件更新机制 2 虚拟DOM配合Diff算法 3 减轻state 4 shouldComponentUpdate() 4.1 基本使用 4.2 使用参数 5 纯组件 5.1 基本使用 5.2 纯组件的比较方法 shallow compere 1 组件更新机制 当父组件重新渲染时&#xff0c;父组件的所有子组件也会重新…...

国产化大趋势下学习linux的必要性

由于国际上的一些国家的制裁和威胁。最近几年国产化大趋势慢慢的兴起&#xff0c;我们国产化硬件的需求越来越大。对国产操作系统的需求也越来越多&#xff0c;那么我们一直用的Windows系统为什么不用了呢&#xff1f;众所周知的原因&#xff0c;不管是最新的Windows11还是正值…...

浅谈虚树

问题引入 你是否遇到过下面这种问题&#xff1a; SDOI2011 消耗战 在一场战争中&#xff0c;战场由 nnn 个岛屿和 n−1n-1n−1 个桥梁组成&#xff0c;保证每两个岛屿间有且仅有一条路径可达。现在&#xff0c;我军已经侦查到敌军的总部在编号为1的岛屿&#xff0c;而且他们已…...

裸机条件下写一个基于时间片轮转的多任务并发程序

目录前言A. 使用RTOSB.裸机多任务并发前言 在学习各种MCU的时候&#xff0c;都是用在main函数里写一个while(1){/* 执行代码 */}&#xff0c;这种方式只能一个函数运行完以后再运行另一个函数。 假设需求控制多个模块&#xff0c;如显示屏幕信息的同时控制电机&#xff0c;还要…...

RK3588 系统定制开关机动画

平台&#xff1a;ITX-3588J, ROC-RK3588S-PC 系统&#xff1a;Android12.0 作者&#xff1a;jpchen & zzz 一. 功能描述 定制自己的开机动画和关机动画 二. 功能实现 1.开启功能 修改device/rockchip/common/BoardConfig.mk文件 BOOT_SHUTDOWN_ANIMATION_RINGINGtrue2.…...

水文-编程命令快查手册

前言 脑子里面记不住一些命令&#xff0c;每次遇到都得查下。我经常在三个实体电脑&#xff0c;windows/uos/ubuntu不同系统上编程。 所以web版本的笔记查看起来方便点。这里报错下。 二级标题 cmake windows在cmake --build的时候&#xff0c;使用–config&#xff0c;指定…...

CANN/asc-devkit向量取反API

asc_neg 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言&#xff0c;原生支持C和C标准规范&#xff0c;主要由类库和语言扩展层构成&#xff0c;提供多层级API&#xff0c;满足多维场景算子开发诉求。 项目地址: https://gitcode.com/ca…...

Lean开发环境终极解决方案:3步完成版本管理工具配置

Lean开发环境终极解决方案&#xff1a;3步完成版本管理工具配置 【免费下载链接】elan The Lean version manager 项目地址: https://gitcode.com/gh_mirrors/el/elan elan是专为Lean定理证明器设计的智能版本管理工具&#xff0c;能够自动处理Lean和lake二进制文件的安…...

BlockingQueue实现原理与生产者消费者模式

前言 在现代软件开发中&#xff0c;BlockingQueue实现原理与生产者消费者模式是一个非常重要的技术点。本文将从原理到实践&#xff0c;带你深入理解这一技术&#xff0c;并通过完整的代码示例帮助你快速掌握核心知识点。 核心概念 基本原理 BlockingQueue实现原理与生产者消费…...

3分钟掌握PlantUML Editor:用代码思维绘制专业UML图表的终极指南

3分钟掌握PlantUML Editor&#xff1a;用代码思维绘制专业UML图表的终极指南 【免费下载链接】plantuml-editor PlantUML online demo client 项目地址: https://gitcode.com/gh_mirrors/pl/plantuml-editor 还在为复杂的UML图表绘制而烦恼吗&#xff1f;传统的拖拽式绘…...

从低空协议劫持实战看 MAVLink 二进制审计在飞控发布环节的必要性

攻防实测复盘&#xff1a;协议劫持漏洞成因解析无人机接管攻击的本质不是高危漏洞&#xff0c;而是协议与生俱来的默认信任逻辑。近期多项低空攻防实测中&#xff0c;攻击者依托通用射频采集设备&#xff0c;即可持续捕获空口无线交互数据&#xff0c;实现对飞行设备的非正常控…...

Midjourney景深模糊失效全解析,深度拆解--no参数干扰链、背景层剥离阈值及alpha通道注入技巧

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Midjourney景深效果控制的底层逻辑与失效本质 Midjourney 并未提供原生的、参数化的景深&#xff08;Depth of Field, DoF&#xff09;控制机制。其所谓“景深效果”实为提示词引导下的隐式风格模仿&a…...

别再让日志拖慢你的服务器!深入对比C++同步与异步日志的性能差异(附TinyWebServer实测)

C服务器日志性能优化实战&#xff1a;同步与异步方案深度对比 当你的Web服务器开始承载真实流量时&#xff0c;那些看似无害的日志语句可能正在悄悄吞噬着系统性能。我曾在一个电商促销日亲眼目睹&#xff0c;由于同步日志的阻塞导致服务器响应时间从50ms飙升到800ms&#xff0…...

Unity节点化效率工具:ComfyUI范式赋能中大型项目开发

1. 这不是又一个“UI美化插件”&#xff0c;而是Unity开发者每天要敲十次的底层效率杠杆Efficiency Nodes ComfyUI——光看名字&#xff0c;很多人第一反应是“ComfyUI&#xff1f;那不是Stable Diffusion的可视化工作流工具吗&#xff1f;怎么跑Unity里来了&#xff1f;”这恰…...

免费去图片水印app排行榜怎么选?2026一键去水印工具推荐

日常生活中&#xff0c;我们经常会遇到需要去除图片水印的情况——无论是保存他人分享的精美图片、整理素材库&#xff0c;还是为了个人使用和内容二次创作。市场上有许多去水印工具&#xff0c;但质量参差不齐&#xff0c;收费模式也各不相同。本文为你盘点了2026年最实用的免…...

Unity哥特UI资源包:SDF字体与Shader Graph工程化实践

1. 为什么哥特UI在游戏开发中长期被低估&#xff0c;又为何现在必须认真对待“哥特UI”这个词&#xff0c;很多Unity开发者第一反应是&#xff1a;不就是黑底、尖角、浮雕字、带玫瑰纹样的按钮吗&#xff1f;配个暗红渐变完事。我2019年接手一个中世纪黑暗奇幻RPG时也这么想——…...