菜鸟刷题Day6

news/2024/11/24 11:09:38/

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

一.链表内指定区间反转:链表内指定区间反转_牛客题霸_牛客网 (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;
}

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


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

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


http://www.ppmy.cn/news/34965.html

相关文章

官宣|Apache Flink 1.17 发布公告

Apache Flink PMC&#xff08;项目管理委员&#xff09;很高兴地宣布发布 Apache Flink 1.17.0。Apache Flink 是领先的流处理标准&#xff0c;流批统一的数据处理概念在越来越多的公司中得到认可。得益于我们出色的社区和优秀的贡献者&#xff0c;Apache Flink 在 Apache 社区…

CAN通信----电路图

CAN通信----基本原理 一、CAN总线网络连接 1.闭环总线网络----ISO11898 闭环总线网络高速、短距离&#xff0c;它的总线最大长度为 40m&#xff0c;通信速度最高为 1Mbps&#xff0c;总线的两端各要求有一个120 欧的电阻。 2.开环总线网络----ISO11519 开环总线网络低速、…

【算法】回溯法详解

一、概述 回溯法在包含的所有可能解的解空间树中&#xff0c;从根节点出发&#xff0c;按照深度有限的策略进行搜索&#xff0c;对于解空间树的某个结点&#xff0c;如果该节点满足问题的约束条件&#xff0c;则进入该子树继续进行搜索&#xff0c;否则将以该节点为根节点进行…

冲击蓝桥杯-并查集,前缀和,字符串

目录 前言 一、并查集 1、并查集的合并&#xff08;带路径压缩&#xff09; 2、询问是否为同一个集合 3、例题 二、前缀和 1 、前缀和是什么 2、经典题目 三- 字符串处理 1、字符串的插入 2、字符串转化为int类型 3、字符反转 前言 并查集合前缀&#xff0c;字符串…

《Qt 6 C++开发指南》提供4个版本的示例程序

《Qt 6 C开发指南》包含丰富的示例项目&#xff0c;为了方便读者使用《Qt 6 C开发指南》学习Qt编程&#xff0c;本书提供了4个版本的示例程序。读者可在人民邮电出版社异步社区本书的配套资源&#xff08;如图1&#xff09;里下载这4个版本的示例程序。图1 异步社区本书配套资源…

【机器学习基础 3】 sklearn库

目录 一、sklearn库简介 二、sklearn库安装 三、关于机器学习 四、sklearn库在机器学习中的应用 1、数据预处理 2、特征提取 3、模型选择与评估 五、常用的sklearn函数 1、数据集划分 2、特征选择 3、特征缩放 4、模型训练 5、模型预测 一、sklearn库简介 Scikit-l…

ChatGPT 有哪些神奇的使用方式?

ChatGPT在语言处理领域有着非常广泛的应用&#xff0c;可以用来进行语音识别、文本摘要、问答系统、机器翻译、智能客服、情感分析、智能写作等方面的应用。随着技术的不断发展和进步&#xff0c;ChatGPT在未来的应用场景和领域也将会有更加广泛的拓展和应用。ChatGPT可以应用于…

6.网络爬虫——BeautifulSoup详讲与实战

网络爬虫——BeautifulSoup详讲与实战BeautifulSoup简介&#xff1a;BS4下载安装BS4解析对象Tag节点遍历节点find_all()与find()find_all()find()豆瓣电影实战前言&#xff1a; &#x1f4dd;​&#x1f4dd;​此专栏文章是专门针对网络爬虫基础&#xff0c;欢迎免费订阅&#…