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

网站客服模版sem

网站客服模版,sem,长沙口碑好网站建设公司,动态web网站开发技术🔥个人主页:艾莉丝努力练剑 ❄专栏传送门:《C语言》、《数据结构与算法》、C语言刷题12天IO强训、LeetCode代码强化刷题 🍉学习方向:C/C方向 ⭐️人生格言:为天地立心,为生民立命,为…

 


🔥个人主页:艾莉丝努力练剑

❄专栏传送门:《C语言》、《数据结构与算法》、C语言刷题12天IO强训、LeetCode代码强化刷题

🍉学习方向:C/C++方向

⭐️人生格言:为天地立心,为生民立命,为往圣继绝学,为万世开太平


前言:牛客网和LeetCode的刷题都不可或缺,我们都要做一做,无论是参加竞赛还是笔试面试,至少能提升你的代码能力!洛谷的题目也可以去做一做。力扣的题目对提升代码能力很有帮助,需要有一点基础,几乎都是接口型的题目,关于接口型和IO型的区别我们在本专栏的第一篇【LeetCode】力扣题——轮转数组、消失的数字、数组串联中就介绍过了,这里不再赘述。


 


目录

正文 

一、反转链表问题

1、思路

2、解题过程

3、另外的思路 

二、链表的中间节点问题

1、思路

2、解题过程

(1)奇数

(2)偶数

非常值得注意的一点 

3、另外的思路

结尾


正文 

一、反转链表问题

206.反转链表

博主题解链接:三指针解决反转链表问题

大家可以直接去看博主在力扣上面写的题解,还是比较详细的。

题目描述:

像这种题目拿到手我们首先就是想到要画图,一定要有这个意识,数据结构的算法题一定要画图。

比如我们这里直接把题目中示例1的示例图截图扣下来,粘贴到画图板上——

接下来才能有思路—— 

1、思路

我们选用的方法:创建三个指针,改变指针的指向。

2、解题过程

如下图所示——

代码演示:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
typedef struct ListNode ListNode;
struct ListNode* reverseList(struct ListNode* head) 
{if(head == NULL){return head;}//创建三个指针ListNode* n1,*n2,*n3;if(n2)n1 = NULL,n2 = head,n3 = n2->next;while(n2){n2->next = n1;n1 = n2;n2 = n3;if(n3)n3 = n3->next;}return n1;
}

复杂度:时间复杂度: O(N) ,空间复杂度: O(1) 。

3、另外的思路 

有思路2就肯定有思路1,只不过思路1大家都想得到,不太有讲解的必要。

 思路1:创建新链表,遍历原链表,将头节点插到新链表中——

时间复杂度:O(N)。

二、链表的中间节点问题

876.链表的中间节点

博主题解链接:快慢指针求解单链表中间节点问题

大家直接去看博主在力扣上面写的题解也是可以的。

题目描述:

再强调一遍,一定要有这个画图的意识,数据结构的算法题真的一定要画图。

1、思路

我们选用的方法:快慢指针

快慢指针是一个非常重要的方法,我们一定要重视。后面还会有几道题要用到快慢指针。

2、解题过程

这几次单链表相关的力扣题目,博主都用画图软件画了图,就不多赘述了,大家看图。

解题过程:创建快慢指针slow、fast,慢指针每次走一步,快指针每次走两步,我们分为奇数和偶数两种情况讨论,看两者是否满足条件——

(1)奇数

条件:fast->next != NULL; 

(2)偶数

 条件:fast != NULL;

非常值得注意的一点 

这里表达式不能像下面图中这样写,顺序不能倒,fast != NULL一定是在前面,因为如果fast->next != NULL在前面,如果这时候偶数fast为空,&&表达式就短路了,短路了就走不到&&后面的表达式里面了,空指针不能解引用——

代码演示:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/typedef struct ListNode ListNode;
struct ListNode* middleNode(struct ListNode* head) 
{//创建快慢指针ListNode* slow = head;ListNode* fast = head;while(fast != NULL && fast->next != NULL){slow = slow->next;fast = fast->next->next;}return slow;
}

复杂度:时间复杂度: O(n),空间复杂度: O(1)

3、另外的思路

有思路2就肯定有思路1,只不过思路1大家都想得到,不太有讲解的必要。

思路1:我们就去求链表总长度,总长度/2取整就是链表中间节点的位置。 

我们去找中间节点——

while()
{...
}

我们写“求链表总长度” ,size我们知道是有效长度,size的一半就是中间节点的位置。

我们这个while(mid)——就是根据mid找中间节点。

我们后面会讲一道题目,就用到了这个方法,这里先卖个关子。 


结尾

往期回顾:

【LeetCode】用双指针解决移除元素问题、合并两个有序数组求解

【LeetCode】力扣题——轮转数组、消失的数字、数组串联

结语:本篇文章到这里就结束了,本文讲述的两道代码题并不适合C语言初学者,需要有一定的C语言基础,最好要学过数据结构与算法的算法复杂度和链表的知识,才能写出复杂度较优的代码来。大家一定要自己动手敲一敲,不敲的话不仅容易忘记,也不方便将来复习。

http://www.dtcms.com/wzjs/460207.html

相关文章:

  • 青岛做教育的网站建设app推广项目
  • 网站开发费属于无形资产那部分免费注册推广网站
  • 深圳网站建设 罗湖网络营销案例分析ppt
  • 网站 演示代码百度指数分析数据
  • 建设网站的一般过程开发客户的70个渠道
  • 制作网站如何选择主机网站制作推广
  • 凡科删除建设的网站今日头条新闻消息
  • 城乡住房和城乡建设部网站首页seo服务如何收费
  • 安装网站系统登封网络推广
  • 兴化建设局网站2021年经典营销案例
  • 公司做网站费用百度一下百度搜索百度一下
  • wordpress网站之间互联成免费的crm
  • 做科研找论文的网站怎么在百度上投放广告
  • 找网站开发公司seo推广价格
  • 网站建设服务商 需要什么主机百度热榜
  • 商城网站 免费开源头条收录提交入口
  • 如何做企业网站界面营销网络的建设
  • 静态网站中切换图片怎么做如何制定会员营销方案
  • 把自己做的动画传到哪个网站上实时排名软件
  • 网站开发属于百度高级搜索怎么用
  • 蒙古网站做奶食网站免费搭建平台
  • 企业推广网站建设报价如何制作网页设计
  • 小企业公司网站建设新闻头条最新消息10条
  • 网站建设webmeng百度投诉平台在哪里投诉
  • 兰州网站制作cheng网站的营销推广方案
  • 做企业网站联系淘宝店怎么运营和推广
  • 巴中商城网站建设网站目录提交
  • 自己做网站多少钱小程序制作
  • 中建西部建设北方有限公司网站百度app
  • 工作期间员工花钱做的网站4p营销理论