leetcode刷题(数组和链表阶段)

目录

前言

一、数组模块

1.二分查找

2.双指针法

二、链表模块

1.双指针法

2.环形链表

三、递归

总结


前言

这个模块专门用来记录自己刷leetcode的新的,每刷完一个部分或者有新的感悟就会过来把他加入到这个模块里面,目前刷了刷数组和链表部分的习题,把最近的一些想法记录下来


提示:以下是本篇文章正文内容,

一、数组模块

        数组这里的题倒不是特别难,但是挺考验程序员对代码的掌控能力的。

1.二分查找

        二分查找考验的是,自己对区间的掌握程度,就是写循环的时候,边界的掌握,是左闭右闭,还是左闭右开,这个得掌握好。

2.双指针法

        数组和链表这块,一般都可以使用这个双指针法,会加快解题速度,比如这几道题:移除元素、有序数组平方 、 长度最小的子数组都可以用双指针法。比如长度最小的子数组这道题,利用双指针法就可以非常巧妙地把题解出来。

二、链表模块

        链表这块有两点注意:

                1.就是链表在操作过程中,最好弄出来一个虚拟头节点,这样会方便我们进行操作链表,从我们思考的方面也会更加方便,可以在最后返回值时给头节点去掉。

                2.链表一般都和递归有关,因为链表本身就是利用递归定义的,所以大多数题都可以利用递归来解题,比如:反转链表两两交换节点,尤其是两两交换这道题,利用递归解法特别巧妙,同时也考验我们对递归的理解,理解不是很清楚的话,这个递归还是比较难写出来的。

1.双指针法

        链表这里双指针就特别管用了,比如删除链表的倒数第N个节点,这个就可以用快慢指针法来解题,链表相交这道题同理。

2.环形链表

        这道题也是双指针法,不过最好要特殊记忆一下,他的推导公式看一下就行,记住大概原理

三、递归

        既然链表那块提到递归了,我就把我最近写递归函数的一些感悟记录一下。递归要注意三点问题,其实也可以说为两点。

        1.递推式,递推式就是一层一层往下走的过程,在写函数时不要给这个考虑的太复杂,只想一层就行,不用想下一层会是什么样的,因为下一层和这一层情况是一样的,如果你一直想下一层是什么样的,写函数时脑子就会特别复杂,因为你自己已经陷入递归中了,所以说不用想下一层怎们办,就把这一层写好就行了。

       2.递归结束条件,这个专业名词好像叫做递归基,在写完递归式,就要想递归基的问题了,这个意味着我们什么时候结束。

        3.每一层递归中变量之间的关系,这个是新手写递归最容易忽略的问题,本来怎们想怎么感觉自己递归写的没毛病,但是结果就是不对,原因很可能出现在变量中了。

        (1) 如果递归函数中传入的参数是引用类型的,在下一层改变引用所指向的数值时,所有层中的变量都会发生改变。

        (2)但是传入的是普通类型,你在这一层对变量的修改,是不会改变上一层改变量的值,如果你还需要该值,就需要用return进行返回。

        (3)还有一种可能就是,没有给传入参数,但是用的全局变量,这种情况,就和第一种比较类似了

        总而言之,每进入一层递归,就代表新调用了一个函数,就会给函数参数开辟新的临时空间,在递归回溯时,这个空间会被收回,所以很可能影响不到上一层递归的变量值。把这句话弄懂了,就是以上三种的总结。


总结

这块算法是跟着这个网站顺序进行刷题的,感兴趣的小伙伴可以和我一起来刷。

代码随想录

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用\[1\]和引用\[2\]的内容,推荐的LeetCode刷题顺序是按照题目类型刷题,优先选择树、链表、二分查找、DFS、BFS、动态规划等常见类型的题目。可以先做2~4道简单题,然后再做中等难度的题目。在选择题目时,可以优先选择题目序号小、点赞多、提交成功率高的题目,这样可以从简单入手,节省时间。同时,LeetCode每道题目都有“模拟面试”功能,可以给自己设定时间限制,如果做不出来可以看答案,然后记住思路后再自己尝试一遍。每种类型的题目做完10+道后,可以总结规律。 根据引用\[3\]的内容,题目可以按照不同的分类进行刷题,比如数组与贪心算法、子数组与贪心算法、子序列与贪心算法、数字与贪心、单调栈法、双指针法等。可以根据自己的兴趣和需求选择相应的题目进行刷题。 综上所述,LeetCode刷题顺序可以按照题目类型或者题目分类进行选择。 #### 引用[.reference_title] - *1* [LeetCode 刷题顺序,按标签分类,科学刷题!](https://blog.csdn.net/fengyuyeguirenenen/article/details/125099023)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [leetcode 刷题指南 & 刷题顺序](https://blog.csdn.net/qijingpei/article/details/125561071)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [leetcode-刷题顺序推荐](https://blog.csdn.net/weixin_38087674/article/details/114107841)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值