E-COM-NET
首页
在线工具
Layui镜像站
SUI文档
联系我们
推荐频道
Java
PHP
C++
C
C#
Python
Ruby
go语言
Scala
Servlet
Vue
MySQL
NoSQL
Redis
CSS
Oracle
SQL Server
DB2
HBase
Http
HTML5
Spring
Ajax
Jquery
JavaScript
Json
XML
NodeJs
mybatis
Hibernate
算法
设计模式
shell
数据结构
大数据
JS
消息中间件
正则表达式
Tomcat
SQL
Nginx
Shiro
Maven
Linux
Leetcode(贪心)
经典算法题汇总
目录1.动态规划/回溯1.1最长公共子序列(牛客版,
leetcode
1143)1.2最长上升子序列(
leetcode
300)1.3最长回文子串(牛客版,
leetcode
5)1.4接雨水1.5重复数字的所有排列
qq_36696761
·
2024-09-05 09:33
C语言 |
Leetcode
C语言题解之第385题迷你语法分析器
题目:题解:#defineMAX_NEST_LEVEL50001structNestedInteger*deserialize(char*s){if(s[0]!='['){structNestedInteger*ni=NestedIntegerInit();NestedIntegerSetInteger(ni,atoi(s));returnni;}structNestedInteger**stac
DdddJMs__135
·
2024-09-05 07:21
分享
C语言
Leetcode
题解
Leetcode
每日一题:Remove Nth Node From End of List
写在前面:今天来看一道不怎么难的题,给大家放松一下。放松的同时也希望和大家一起回顾一下“链表”LinkedList的一些基本知识和使用方法。链表是面试里常考察的题型之一,他和array最大的不同之处在于他更好的延展性,比数组,甚至是动态数组对于不元素大小的头尾增删效率更加,因为不需要对内存空间长度的重新分配。与之带来的缺点就是从全局角度来说的“长度不可见”,“位置不可见”,所有的长度和位置都依赖于
南加第一划水
·
2024-09-05 07:49
Leetcode
每日一题
leetcode
list
算法
Golang |
Leetcode
Golang题解之第386题字典序排数
题目:题解:funclexicalOrder(nint)[]int{ans:=make([]int,n)num:=1fori:=rangeans{ans[i]=numifnum*10n{num/=10}num++}}returnans}
__AtYou__
·
2024-09-05 07:17
经验分享
Golang
Leetcode
题解
Java |
Leetcode
Java题解之第385题迷你语法分析器
题目:题解:classSolution{publicNestedIntegerdeserialize(Strings){if(s.charAt(0)!='['){returnnewNestedInteger(Integer.parseInt(s));}Dequestack=newArrayDeque();intnum=0;booleannegative=false;for(inti=0;i1){N
m0_57195758
·
2024-09-05 06:44
分享
Java
Leetcode
题解
简化路径【 力扣(
LeetCode
) 】
一、题目描述给你一个字符串path,表示指向某一文件或目录的Unix风格绝对路径(以‘/’开头),请你将其转化为更加简洁的规范路径。在Unix风格的文件系统中,一个点(.)表示当前目录本身;此外,两个点(…)表示将目录切换到上一级(指向父目录);两者都可以是复杂相对路径的组成部分。任意多个连续的斜杠(即,‘//’)都被视为单个斜杠‘/’。对于此问题,任何其他格式的点(例如,‘…’)均被视为文件/目
理论最高的吻
·
2024-09-05 06:12
leetcode
算法
职场和发展
C++
栈
leetcode
-227. 基本计算器 II
题目实现一个基本的计算器来计算一个简单的字符串表达式的值。字符串表达式仅包含非负整数,+,-,*,/四种运算符和空格。整数除法仅保留整数部分。示例1:输入:"3+2*2"输出:7示例2:输入:"3/2"输出:1示例3:输入:"3+5/2"输出:5解题思路Consider-asnegativenumbers说是栈的经典应用,结果好难做,哭哭最基本的题目,参考了这篇题解:https://leetcod
KpLn_HJL
·
2024-09-05 06:40
OJ题目记录
leetcode
算法
职场和发展
Leetcode
面试经典150题-54.螺旋矩阵
解法都在代码里,不懂就留言或者私信这个题可能和算法关联不大,coding技巧为上classSolution{publicListspiralOrder(int[][]matrix){/**先定义结果集*/Listans=newArrayListexistsSet=newHashSet=0&&colNext>=0&&rowNext
鱼跃鹰飞
·
2024-09-05 05:36
数据结构与算法
字节跳动高频面试题
leetcode
面试
算法
基本计算器【 力扣(
LeetCode
) 】
一、题目描述给你一个字符串表达式s,请你实现一个基本计算器来计算并返回它的值。注意:不允许使用任何将字符串作为数学表达式计算的内置函数,比如eval()。二、测试用例示例1:输入:s="1+1"输出:2示例2:输入:s="2-1+2"输出:3示例3:输入:s="(1+(4+5+2)-3)+(6+8)"输出:23提示:1op_set={{"n",1},{"+",1},{"-",1},{"(",2},
理论最高的吻
·
2024-09-05 05:35
leetcode
算法
职场和发展
C++
栈
逆波兰表达式
常见的算法底层思想
3.
贪心
算法思想:在每一步选择中都采取在当前状态下最好或最优的选择,从而希望导致结果是全
qinbaby
·
2024-09-05 04:58
算法
LeetCode
2860.让所有学生保持开心的分组方法数:排序+遍历
【LetMeFly】2860.让所有学生保持开心的分组方法数:排序+遍历力扣题目链接:https://
leetcode
.cn/problems/happy-students/给你一个下标从0开始、长度为
Tisfy
·
2024-09-05 03:50
题解
#
力扣LeetCode
leetcode
算法
数据结构
题解
排序
贪心
遍历
leetcode
算法题之N皇后
N皇后也是一道很经典的问题,问题如下:题目地址按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。n皇后问题研究的是如何将n个皇后放置在n×n的棋盘上,并且使皇后彼此之间不能相互攻击。给你一个整数n,返回所有不同的n皇后问题的解决方案。每一种解法包含一个不同的n皇后问题的棋子放置方案,该方案中'Q'和'.'分别代表了皇后和空位。解法:回溯回溯是基于DFS的一种算法,它通过在解
前端码农小黄
·
2024-09-05 02:45
算法
算法
leetcode
【
LeetCode
-SQL每日一练】——2. 第二高的薪水
接下来小梦会带领小伙伴们一起每天刷一道
LeetCode
-数据库(SQL)相关的题目,然后在文章后例举相关知识点帮助小伙伴们学习与巩固,更好的掌握SQL。??♂小伙伴们如果在学习过程中有不
m0_67401920
·
2024-09-05 01:14
面试
学习路线阿里巴巴
android
前端
后端
LeetCode
C++10-K个一组翻转链表
问题描述给你一个链表,每k个节点一组进行翻转,请你返回翻转后的链表。k是一个正整数,它的值小于或等于链表的长度。如果节点总数不是k的整数倍,那么请将最后剩余的节点保持原有的顺序。举例示例1:输入:1->2->3->4->5k=2输出:2->1->4->3->5示例2:输入:1->2->3->4->5k=3输出:3->2->1->4->5示例3:输入:1->2->3->4->5k=1输出:1->2-
JXH_123
·
2024-09-05 01:42
LeetCode高频算法面试题
算法
c++
leetcode
leetcode
算法题之 K 个一组翻转链表
照我说这道题其实是披着困难皮的中等题目,问题如下:题目地址给你链表的头节点head,每k个节点一组进行翻转,请你返回修改后的链表。k是一个正整数,它的值小于或等于链表的长度。如果节点总数不是k的整数倍,那么请将最后剩余的节点保持原有顺序。你不能只是单纯的改变节点内部的值,而是需要实际进行节点交换。解法:首先我们来看一个更简单的问题,就是如何进行原地反转链表反转链表其实很简单,通过几个变量就可以实现
前端码农小黄
·
2024-09-05 01:12
算法
算法
leetcode
链表
LeetCode
全排列2(js简单快通法)
题目描述给定一个可包含重复数字的序列nums,按任意顺序返回所有不重复的全排列。示例1:输入:nums=[1,1,2]输出:[[1,1,2],[1,2,1],[2,1,1]]示例2:输入:nums=[1,2,3]输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]解题思路使用全排列函数生成所有排列,然后去重以得到最终结果代码/***@param{
山雀~
·
2024-09-05 01:42
LeetCode合集
leetcode
javascript
算法
Leetcode
-有效的数独
相信喜欢玩数独的朋友们肯定能猜出这道题的要求了哈哈。请你判断一个9x9的数独是否有效。只需要根据以下规则,验证已经填入的数字是否有效即可:数字1-9在每一行只能出现一次。数字1-9在每一列只能出现一次。数字1-9在每一个以粗实线分隔的3x3宫内只能出现一次。(请参考示例图)注意:一个有效的数独(部分已被填充)不一定是可解的。只需要根据以上规则,验证已经填入的数字是否有效即可。空白格用'.'表示。解
Liu_Junwei
·
2024-09-05 01:09
算法
leetcode
算法
【
leetcode
】- 83.Remove Duplicates from Sorted List
1、题目描述Givenasortedlinkedlist,deleteallduplicatessuchthateachelementappearonlyonce.Example1:Input:1->1->2Output:1->2Example2:Input:1->1->2->3->3Output:1->2->32、问题描述:删除链表中重复的值。3、问题关键:双指针,因为是排好序的,一个先走,指导
邓泽军_3679
·
2024-09-05 01:25
LeetCode
算法:零钱兑换 c++
原题链接:零钱兑换难度:中等⭐️⭐️题目给你一个整数数组coins,表示不同面额的硬币;以及一个整数amount,表示总金额。计算并返回可以凑成总金额所需的最少的硬币个数。如果没有任何一种硬币组合能组成总金额,返回-1。你可以认为每种硬币的数量是无限的。示例1:输入:coins=[1,2,5],amount=11输出:3解释:11=5+5+1示例2:输入:coins=[2],amount=3输出:
Codec Conductor
·
2024-09-04 23:02
力扣
算法
leetcode
c++
动态规划
数据结构
Golang |
Leetcode
Golang题解之第386题字典序排数
题目:题解:funclexicalOrder(nint)[]int{ans:=make([]int,n)num:=1fori:=rangeans{ans[i]=numifnum*10n{num/=10}num++}}returnans}
__AtYou__
·
2024-09-04 21:15
经验分享
Golang
Leetcode
题解
Leetcode
146. LRU 缓存(Medium)
请你设计并实现一个满足LRU(最近最少使用)缓存约束的数据结构。实现LRUCache类:LRUCache(intcapacity)以正整数作为容量capacity初始化LRU缓存intget(intkey)如果关键字key存在于缓存中,则返回关键字的值,否则返回-1。voidput(intkey,intvalue)如果关键字key已经存在,则变更其数据值value;如果不存在,则向缓存中插入该组k
会有黎明吗
·
2024-09-04 20:44
leetcode
leetcode
缓存
spring
LeetCode
-209-长度最小的子数组
示例说明请见
LeetCode
官网。来源:力扣(
LeetCode
)链接:https://
leetcode
-cn.com/problems/minim
醉舞经阁半卷书
·
2024-09-04 18:26
单调递增的数字 ----
贪心
738单调递增的数字给定一个非负整数N,找出小于或等于N的最大的整数,同时这个整数需要满足其各个位数上的数字是单调递增。(当且仅当每个相邻位数上的数字x和y满足x<=y时,我们称这个整数是单调递增的。)示例1:输入:N=10输出:9示例2:输入:N=1234输出:1234示例3:输入:N=332输出:299Notes:【c++】整数转字符串:to_string(N),字符串转整数stoi(str_
allesistgut
·
2024-09-04 17:55
字符串
贪心算法
leetcode
字符串
贪心算法
每日一题:力扣738. 单调递增的数字
题目链接:https://
leetcode
-cn.com/problems/monotone-increasing-digits/题目给定一个非负整数N,找出小于或等于N的最大的整数,同时这个整数需要满足其各个位数上的数字是单调递增
看了个寂寞
·
2024-09-04 17:53
算法
leetcode
贪心算法
738. 单调递增的数字
题目难度:中等类型:
贪心
题意:遇到逆序,就将当前位减1,同时将后面的数全部置为9。循环判断检查前面是否产生了逆序。
SYaoJun
·
2024-09-04 16:22
LeetCode经典题
贪心算法
【动态规划】343. 整数拆分
力扣链接:343.整数拆分-力扣(
LeetCode
)dp数组的含义:dp[i]表示对i拆分,得到最大的积为dp[i]递推公式:拆成两个数是j*(i-j),拆成三个及以上是j*dp[i-j],所以递推公式取两者大值遍历顺序
羊毛_
·
2024-09-04 15:17
力扣刷题记录
动态规划
算法
Leetcode
662. Maximum Width of Binary Tree
文章作者:Tyan博客:noahsnail.com|CSDN|1.DescriptionMaximumWidthofBinaryTree2.Solution/***Definitionforabinarytreenode.*structTreeNode{*intval;*TreeNode*left;*TreeNode*right;*TreeNode(intx):val(x),left(NULL),
SnailTyan
·
2024-09-04 15:18
LeetCode
2860. 让所有学生保持开心的分组方法数 (排序、枚举)
题目:2860.让所有学生保持开心的分组方法数思路:先将数组nums进行升序排序。然后假设第i-1位学生选中,而第i位学生没有选中,并且所有学生都符合开心要求。那么根据开心要求,[0,i-1]的学生,nums值都是小于被选中的人数k;且[i,n-1]的学生,nums值都是大于被选中的人数k。这时被选中的人数就是i,即nums[i-1]0时,可以一个学生都不选。当nums[n-1]&nums){so
岁忧
·
2024-09-04 13:29
LeetCode
leetcode
算法
职场和发展
c++
暴力枚举
数据结构
LeetCode
-977-有序数组的平方
给定一个按非递减顺序排序的整数数组A,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。image.png解题思路:暴力法:遍历开平方,再排序;双指针,因为输入A为从小到大排序的,从列表两边开始开方比较,取对比后的较大值,存入ans的末位,以此类推。Python3代码:classSolution:defsortedSquares(self,A:List[int])->List[int]:#a
阿凯被注册了
·
2024-09-04 12:45
2021-05-22
IT1.
LeetCode
力扣:复原IP地址Java编写2021-05-22(93.复原IP地址)英语1.墨墨背单词:复习50个单词
幸福大黑鸭
·
2024-09-04 09:17
【算法】C++
贪心
算法解题(单调递增数字、坏了的计算器、合并区间)
文章目录前言算法题1.单调递增的数字2.坏了的计算器3.合并区间前言关于
贪心
算法/策略的概念、理解性问题在:【算法】
贪心
算法解析:基本概念、策略证明与代码例题演示算法题1.单调递增的数字思路题目要求:找到满足单调递增的
卜及中
·
2024-09-04 08:28
算法
算法
贪心算法
c++
Leetcode
-1143 最长公共子序列 最长公共子串
最长公共子序列:题目描述:给定两个字符串text1和text2,返回这两个字符串的最长公共子序列的长度。如果不存在公共子序列,返回0。一个字符串的子序列是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符(也可以不删除任何字符)后组成的新字符串。例如,"ace"是"abcde"的子序列,但"aec"不是"abcde"的子序列。两个字符串的公共子序列是这两个字符串所共同拥
qq_39622795
·
2024-09-04 08:55
Leetcode
动态规划
最长公共子序列
最长公共子串
字符串处理
二维数组
[Algorithm][综合训练][栈和排序][加减]详细讲解
目录1.栈和排序1.题目链接2.算法原理详解&&代码实现2.加减1.题目链接2.算法原理详解&&代码实现1.栈和排序1.题目链接栈和排序2.算法原理详解&&代码实现解法:栈+
贪心
->每次尽可能先让当前需要的最大值弹出去
DieSnowK
·
2024-09-04 08:54
[OJ]
#
[综合训练]
Algorithm
算法
综合训练
栈和排序
加减
C++
详细讲解
C语言 |
Leetcode
C语言题解之第394题字符串解码
题目:题解:#defineN2000typedefstruct{intdata[30];;inttop;}Stack;voidpush(Stack*s,inte){s->data[(s->top)++]=e;}intpop(Stack*s){returns->data[--(s->top)];}//多位数字串转换成intintstrToInt(char*s){charval[]={'\0','\0
DdddJMs__135
·
2024-09-04 06:11
分享
C语言
Leetcode
题解
Java |
Leetcode
Java题解之第392题判断子序列
题目:题解:classSolution{publicbooleanisSubsequence(Strings,Stringt){intn=s.length(),m=t.length();int[][]f=newint[m+1][26];for(inti=0;i=0;i--){for(intj=0;j<26;j++){if(t.charAt(i)==j+'a')f[i][j]=i;elsef[i][
m0_57195758
·
2024-09-04 06:11
分享
Java
Leetcode
题解
Python |
Leetcode
Python题解之第393题UTF-8编码验证
题目:题解:classSolution:defvalidUtf8(self,data:List[int])->bool:MASK1,MASK2=1int:if(num&MASK1)==0:return1n,mask=0,MASK1whilenum&mask:n+=1ifn>4:return-1mask>>=1returnnifn>=2else-1index,m=0,len(data)whilein
Mopes__
·
2024-09-04 06:40
分享
Python
Leetcode
题解
C++ |
Leetcode
C++题解之第392题判断子序列
题目:题解:classSolution{public:boolisSubsequence(strings,stringt){intn=s.size(),m=t.size();vector>f(m+1,vector(26,0));for(inti=0;i=0;i--){for(intj=0;j<26;j++){if(t[i]==j+'a')f[i][j]=i;elsef[i][j]=f[i+1][j
Ddddddd_158
·
2024-09-04 06:40
经验分享
C++
Leetcode
题解
C++ |
Leetcode
C++题解之第393题UFT-8编码验证
题目:题解:classSolution{public:staticconstintMASK1=14){return-1;}mask>>=1;}returnn>=2?n:-1;}boolvalidUtf8(vector&data){intm=data.size();intindex=0;while(indexm){returnfalse;}for(inti=1;i
Ddddddd_158
·
2024-09-04 06:40
经验分享
C++
Leetcode
题解
Leetcode
Day15 不定长滑动窗口
模版l=0forrinrange(n):count[r]+=1while(不满足):count[l]-=1l+=13无重复的最长连续子串classSolution:deflengthOfLongestSubstring(self,s:str)->int:count={}res=0n=len(s)l=0forrinrange(n):c=s[r]count[c]=count.get(c,0)+1whi
比起村村长
·
2024-09-04 04:58
leetcode
算法
python
数据结构
一起学习
LeetCode
热题100道(32/100)
32.随机链表的复制(学习)给你一个长度为n的链表,每个节点包含一个额外增加的随机指针random,该指针可以指向链表中的任何节点或空节点。构造这个链表的深拷贝。深拷贝应该正好由n个全新节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的next指针和random指针也都应指向复制链表中的新节点,并使原链表和复制链表中的这些指针能够表示相同的链表状态。复制链表中的指针都不应指向原链表中的
久违的小技巧
·
2024-09-04 03:22
学习
leetcode
算法
【无标题】一起学习
LeetCode
热题100道(67/100)
67.寻找旋转排序数组中的最小值(学习)已知一个长度为n的数组,预先按照升序排列,经由1到n次旋转后,得到输入数组。例如,原数组nums=[0,1,2,4,5,6,7]在变化后可能得到:若旋转4次,则可以得到[4,5,6,7,0,1,2]若旋转7次,则可以得到[0,1,2,4,5,6,7]注意,数组[a[0],a[1],a[2],…,a[n-1]]旋转一次的结果为数组[a[n-1],a[0],a[
久违的小技巧
·
2024-09-04 03:22
学习
leetcode
算法
6月第11编
离群索居者,不是神明,便是野兽,但是我
贪心
,我贪恋这人间的烟火气。所以我决定留下来,于时间无涯的荒漠里,正好遇见你,轻声地说一句,哦,原来你也在这里。生活里我们该有的样子,健健康康,快快乐乐,
我是何何子吖
·
2024-09-04 03:13
一起学习
LeetCode
热题100道(65/100)
65.在排序数组中查找元素的第一个和最后一个位置(学习)给你一个按照非递减顺序排列的整数数组nums,和一个目标值target。请你找出给定目标值在数组中的开始位置和结束位置。如果数组中不存在目标值target,返回[-1,-1]。你必须设计并实现时间复杂度为O(logn)的算法解决此问题。示例1:输入:nums=[5,7,7,8,8,10],target=8输出:[3,4]示例2:输入:nums
久违的小技巧
·
2024-09-04 03:21
leetcode
学习
算法
【蓝桥杯青少组】第十五届省赛python(2024)
编程题被绊住了...第四题熟悉等差数列求和公式即可,无需赘述第五题果然是
贪心
算法,之前强化训练了一天,看来效果还是不够。
jikuibu2023
·
2024-09-04 03:50
备战蓝少
蓝桥杯
青少年编程
python
【Hot100】
LeetCode
—153. 寻找旋转排序数组中的最小值
目录1-思路二分2-实现⭐33.搜索旋转排序数组——题解思路3-ACM实现原题链接:153.寻找旋转排序数组中的最小值1-思路二分左区间二分找分界点,二分找到旋转后的分界点即可以nums[mid]为基准,对比nums[0]即可找到区间分界点2-实现⭐33.搜索旋转排序数组——题解思路classSolution{publicintfindMin(int[]nums){intleft=0;intrig
山脚ice
·
2024-09-03 21:15
#
Hot100
leetcode
java
算法
【NO.17】
LeetCode
经典150题-13. 罗马数字转整数
文章目录【NO.17】
LeetCode
经典150题-13.罗马数字转整数解题:模拟【NO.17】
LeetCode
经典150题-13.罗马数字转整数13.罗马数字转整数【简单】罗马数字包含以下七种字符:I
悬浮海
·
2024-09-03 21:15
#
LeetCode
经典150题
leetcode
算法
罗马数字转整数
代码随想录算法训练营第三十二天(动态规划 一)
前几天有点忙加上
贪心
后面好难QWQ暂时跳过两天的
贪心
,开始学动归动态规划理论基础:文章链接:代码随想录文章思维导图:文章摘要:动态规划,英文:DynamicProgramming,简称DP,如果某一问题有很多重叠子问题
map1e_zjc
·
2024-09-03 21:13
算法
动态规划
c++
leetcode
LeetCode
——反转链表&&相交链表
目录一.反转链表题目介绍:代码实现:解题思路:二.相交链表题目介绍:代码实现:分析题目:解题思路:一.反转链表题目介绍:给你单链表的头节点head,请你反转链表,并返回反转后的链表。示例1:输入:head=[1,2,3,4,5]输出:[5,4,3,2,1]示例2:输入:head=[1,2]输出:[2,1]示例3:输入:head=[]输出:[]提示:链表中节点的数目范围是[0,5000]-5000n
宁檬精
·
2024-09-03 21:12
leetcode
链表
javascript
【Hot100】
LeetCode
—33. 搜索旋转排序数组
目录1-思路二分2-实现⭐33.搜索旋转排序数组——题解思路3-ACM实现原题链接:33.搜索旋转排序数组1-思路二分①左区间二分、②寻找目标值所处区间、③二分目标值①左区间二分——>找到最后一个比nums[0]大的元素,也就是前半段即nums[mid]>=nums[0]②寻找目标值所在区间if(target>=nums[0])——>left=0;else{left=left+1;right=nu
山脚ice
·
2024-09-03 20:11
#
Hot100
leetcode
算法
代码随想录算法训练营第三十四天(动态规划 二)
-力扣(
LeetCode
)题面:一个机器人位于一个mxn网格的左上角(起始点在下图中标记为“Start”)。机器人每次只能向下或者向右移动一步。
map1e_zjc
·
2024-09-03 20:40
动态规划
算法
c++
leetcode
上一页
2
3
4
5
6
7
8
9
下一页
按字母分类:
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
其他