草庐IT

LeetCode - 三数之和

全部标签

leetcode第 381 场周赛最后一题 差分,对称的处理

第381场周赛-力扣(LeetCode)最后一题3017.按距离统计房屋对数目II-力扣(LeetCode)dijkstra超时了,看了灵神的解题方法力扣(LeetCode)官网-全球极客挚爱的技术成长平台,其实是差分优化的暴力统计灵神说的“撤销操作”,就是先不加那条xy新路,统计出所有距离对数,然后再加上那条路做修改。做修改需要推一下变短的位置。灵神封装写的特别好,这道题不封装一下,有问题改起来很麻烦。目录统计原始距离对数:找规律:灵神暴力左右:差分:做修改:第一种:第二种:关于小于区间右端点(x+y)/2:(等于过不了)当x==y及x==y+1时没有缩短任何距离。不需要操作参考代码:统计原

算法沉淀——字符串(leetcode真题剖析)

算法沉淀——字符串01.最长公共前缀02.最长回文子串03.二进制求和04.字符串相乘01.最长公共前缀题目链接:https://leetcode.cn/problems/longest-common-prefix/编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串""。示例1:输入:strs=["flower","flow","flight"]输出:"fl"示例2:输入:strs=["dog","racecar","car"]输出:""解释:输入不存在公共前缀。提示:10strs[i]仅由小写英文字母组成思路这里我们可以两两比较,也可以同时比较,这里我使用的是同时

代码随想录算法训练营Day 9|KMP算法:LeetCode28 找出字符串中第一个匹配项的下标、Leetcode459 重复的子字符串

LeetCode28找出字符串中第一个匹配项的下标题目链接:找出字符串中第一个匹配项的下标思路本题考察到了KMP算法,重点在于求next数组。考研时只学会用模式串移动的手算方法求next数组,对于严书中的前后缀做法比较陌生,看了代码随想录的文章和视频才理解,勉强掌握。而且关于next数组有很多种,常见的是将前缀表减一”:右移一位,初始位置为-1;也可以直接将前缀表用来当作next数组,都可以实现next数组,原理上无差别,本题使用前者。关于具体next数组的讲解可见上述文章视频。代码classSolution{public://该next数组为前缀表统一减一(右移一位,初始位置为-1)void

leetcode刷题记录:动态规划02,子序列问题

参考labuladong的算法小抄整理link子序列问题,用一维dp数组或二维dp数组来解决。一维数组:最大子数组和,最长递增子序列。dp[i]的定义:在子数组arr[0…i]中,以arr[i]结尾的子序列的长度是dp[i]。二维数组:主要用于两个数组的情况,如编辑距离,最大公共子序列;也有用在一个数组的情况,比如最长回文子序列foriinrange(n):forjinrange(n):ifarr[i]==arr[j]:dp[i][j]=dp[i][j]+...#累计相同元素的贡献else:dp[i][j]=min(...)#替换为适当的函数或计算方法,更新dp[i][j]的值为选取最大的贡献

【每日一题】LeetCode——反转链表

📚博客主页:爱敲代码的小杨.✨专栏:《JavaSE语法》|《数据结构与算法》|《C生万物》❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️🙏小杨水平有限,欢迎各位大佬指点,相互学习进步!文章目录1.题目描述示例1示例2示例3提示2.思路3.代码1.题目描述给你单链表的头节点head,请你反转链表,并返回反转后的链表。示例1输入:head=[1,2,3,4,5]输出:[5,4,3,2,1]示例2输入:head=[1,2]输出:[2,1]示例3输入:head=[]输出:[]提示链表中节点的数目范围是[0,500]-5000题目链接2.思路判断链表是否为空,如果为空直接返回头结点

华为23年9月笔试原题,巨详细题解,附有LeetCode测试链接

文章目录前言思路主要思路关于f函数的剖析Code就到这,铁子们下期见!!!!前言铁子们好啊!今天阿辉又给大家来更新新一道好题,下面链接是23年9月27的华为笔试原题,LeetCode上面的hard难题,阿辉带大伙来拿下它!!!你可以安排的最多任务数目思路二分和单调队列以及一丢丢贪心主要思路先按照任务难度和工人能力排序二分的范围是[l,r)左闭右开,l=0,r=n+1,最多完成n个任务,n取任务数与工人数的较小值,因为左闭右开,所以r取n+1,最少完成0个任务,所以l取0然后就是如何判断l与r的中点m是否是能够完成的任务数排序的重要就在这里体现了,我们取任务难度最小的m个与能力最强的m个工人如果

算法沉淀——队列+宽度优先搜索(BFS)(leetcode真题剖析)

算法沉淀——队列+宽度优先搜索(BFS)01.N叉树的层序遍历02.二叉树的锯齿形层序遍历03.二叉树最大宽度04.在每个树行中找最大值队列+宽度优先搜索算法(Queue+BFS)是一种常用于图的遍历的算法,特别适用于求解最短路径或最少步数等问题。该算法通常用于在图中寻找从起点到目标点的最短路径。基本思想:初始化队列:将起始节点放入队列中。BFS遍历:从队列中取出一个节点,遍历与该节点相邻且未访问过的节点,将其加入队列。标记已访问:标记已访问的节点,避免重复访问。重复步骤2和3:直到队列为空。这个算法适用于无权图的最短路径问题。在搜索的过程中,每一层级的节点都会被依次访问,直到找到目标节点。具

c++ - 小数位数之和

下面是一道编程面试练习题。处理这个问题的聪明方法是什么?一个数字M以相反的顺序存储在数组中。例如,数字274存储在以下数组中:A[0]=4A[1]=7A[2]=2编写一个函数,给定表示某个数字的数组A,返回数字M*17的十进制表示的数字总和。数组大小可以非常大(超过2,000,000个元素)。 最佳答案 想象一下,您正在手写将153乘以17。它看起来像这样:15317---518517----2601但是您实际上并不需要保存完整的结果;您只需要在进行时添加数字即可。所以在第一步之后你知道最后一位是1,你进了5。然后在第二步之后你知道

LeetCode | 704.二分查找

704.二分查找关于二分查找最重要的就是分类讨论好二分,二分看着好写边界case还是需要测试的哈什么是区间不变量?比如区间取左闭右闭的话那么每次区间二分范围都是新区间的左闭右闭后面做判断时要一直基于这个左闭右闭的区间其实区间定义成开或者闭都没有什么关系只是要明确每次收缩范围后范围内的元素是哪些注意会不会漏掉边界就好大家需要注意二分的几种情况当l=0,r=n的时候因为r这个值我们在数组中无法取到,while(l当l=0,r=n-1的时候因为r这个值我们在数组中可以取到,while(l二分法有多种写法,末尾是开区间闭区间都可以解出寻找单个元素和寻找边界的题目,只需要注意相应的是l其实二分还有很多应

LeetCode 算法分类列表

💡LeetCode高频面试题分类列表,总共24类,312道题目!图133.克隆图207.课程表210.课程表II399.除法求值547.省份数量684.冗余连接743.网络延迟时间785.判断二分图堆215.数组中的第K个最大元素295.数据流的中位数264.丑数II347.前K个高频元素378.有序矩阵中第K小的元素703.数据流中的第K大元素767.重构字符串剑指Offer41.数据流中的中位数栈20.有效的括号71.简化路径84.柱状图中最大的矩形85.最大矩形155.最小栈224.基本计算器227.基本计算器II394.字符串解码402.移掉K位数字503.下一个更大元素II739.每