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(二分查找)
LeetCode
刷题-有序数组的平方
前言说明算法学习,日常刷题记录。题目连接有序数组的平方题目内容给你一个按非递减顺序排序的整数数组nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。示例1:输入:nums=[-4,-1,0,3,10]输出:[0,1,9,16,100]解释:平方后,数组变为[16,1,0,9,100]排序后,数组变为[0,1,9,16,100]示例2:输入:nums=[-7,-3,2,3,11]输出:
小鲨鱼FF
·
2024-02-05 05:40
【数据结构与算法】(6)基础数据结构之栈的链表实现、环形数组实现示例讲解
目录2.5栈1)概述2)链表实现3)数组实现4)应用习题E01.有效的括号-
Leetcode
20E02.后缀表达式求值-
Leetcode
120E03.中缀表达式转后缀E04.双栈模拟队列-
Leetcode
232E05
老牛源码
·
2024-02-05 04:32
数据结构与算法教程
数据结构
链表
java
栈
LeetCode
:字符串中的额外字符
字符串中的额外字符
leetcode
地址:题目地址题目描述:给你一个下标从0开始的字符串s和一个单词字典dictionary。
神说要有光 ye
·
2024-02-05 04:52
算法
#
LeetCode
算法
动态规划
LeetCode
:构造有效字符串的最少插入数
-力扣(
LeetCode
)题目描述:给你一个字符串word,你可以向其中任何位置插入“a”、“b”或“c”任意次,返回使word有效需要插入的最少字母数。
神说要有光 ye
·
2024-02-05 04:52
#
LeetCode
leetcode
算法
算法训练day23
Leetcode
669修建二叉搜索树108将有序数组转换为二叉搜索树538把二叉搜索树转换为累加树
669修建二叉树题目描述https://
leetcode
.cn/problems/trim-a-binary-search-tree/description/我的想法类似于上一题删除节点,在删除操作时增加处理题目分析递归三部曲确定递归函数的参数以及返回值
dc爱傲雪和技术
·
2024-02-05 04:51
算法
算法训练day25
Leetcode
216组合总和17电话号码的字母组合
216组合总和题目描述找出所有相加之和为n的k个数的组合,且满足下列条件:只使用数字1到9每个数字最多使用一次返回所有可能的有效组合的列表。该列表不能包含相同的组合两次,组合可以以任何顺序返回。示例1:输入:k=3,n=7输出:[[1,2,4]]解释:1+2+4=7没有其他符合的组合了。示例2:输入:k=3,n=9输出:[[1,2,6],[1,3,5],[2,3,4]]解释:1+2+6=91+3+
dc爱傲雪和技术
·
2024-02-05 04:20
算法
LeetCode
使循环数组所有元素相等的最少秒数
地址:力扣(
LeetCode
)官网-全球极客挚爱的技术成长平台难度:中等题目描述:给你一个下标从0开始长度为n的数组nums。
神说要有光 ye
·
2024-02-05 04:20
leetcode
算法
2.4学习总结
2.41.不相交的线2.最⼤⼦序和3.判断⼦序列4.不同的子序列5.编辑距离6.零的数列ZeroSum7.迷宫与陷阱https://
leetcode
.cn/problems/uncrossed-lines
啊这泪目了
·
2024-02-05 04:49
学习
2.3学习总结
2.31..买卖股票的最佳时机2..买卖股票的最佳时机II3.最长递增子序列4.最长连续递增的子序列5.最长重复子数组6.最长公共子序列https://
leetcode
.cn/problems/best-time-to-buy-and-sell-stock
啊这泪目了
·
2024-02-05 04:18
学习
2.2学习总结
⼀和零2.零钱兑换II3.组合总和Ⅳ4.零钱兑换5.完全平⽅数6.封印7.杨辉三角形8.卡牌9.最大子段和题1:https://
leetcode
.cn/problems/ones-and-zeroes/
啊这泪目了
·
2024-02-05 04:18
学习
Leetcode
2-两数相加代码详解
Leetcode
2-两数相加文章目录
Leetcode
2-两数相加题目一、示例解析迭代法伪代码python代码递归法伪代码python代码题目给你两个非空的链表,表示两个非负的整数。
白羊by
·
2024-02-05 03:34
力扣算法题-python
开发语言
python
迭代法
递归法
leetcode
Leetcode
1-两数之和详解
Leetcode
1-两数之和文章目录
Leetcode
1-两数之和题目示例解析暴力法伪代码python代码哈希表伪代码python代码题目给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值
白羊by
·
2024-02-05 03:33
力扣算法题-python
Leetcode
python
哈希表
力扣
LeetCode
:Python3代码解析 — 1.两数之和
力扣
LeetCode
:Python解题—1.两数之和两数之和解法一:双循环解法二:缓存数值结果对比两数之和难度:简单给定一个整数数组nums和一个目标值target,请你在该数组中找出和为目标值的那两个整数
Senimo_
·
2024-02-05 03:03
力扣LeetCode
Python3
leetcode
python
算法
容器缓存
两数之和
LeetCode
--代码详解 2.两数相加
2.两数相加题目难度:中等给你两个非空的链表,表示两个非负的整数。它们每位数字都是按照逆序的方式存储的,并且每个节点只能存储一位数字。请你将两个数相加,并以相同形式返回一个表示和的链表。你可以假设除了数字0之外,这两个数都不会以0开头。示例1:输入:l1=[2,4,3],l2=[5,6,4]输出:[7,0,8]解释:342+465=807.示例2:输入:l1=[0],l2=[0]输出:[0]示例3
Java之弟
·
2024-02-05 03:31
LeetCode
leetcode
算法
职场和发展
LeetCode
--代码详解 292.Nim游戏
292.Nim游戏题目你和你的朋友,两个人一起玩Nim游戏:桌子上有一堆石头。你们轮流进行自己的回合,你作为先手。每一回合,轮到的人拿掉1-3块石头。拿掉最后一块石头的人就是获胜者。假设你们每一步都是最优解。请编写一个函数,来判断你是否可以在给定石头数量为n的情况下赢得游戏。如果可以赢,返回true;否则,返回false。示例1:输入:n=4输出:false解释:以下是可能的结果:1.移除1颗石头
Java之弟
·
2024-02-05 03:01
LeetCode
#
贪心算法
leetcode
游戏
算法
LeetCode
--455.分发饼干
假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。对每个孩子i,都有一个胃口值g[i],这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干j,都有一个尺寸s[j]。如果s[j]>=g[i],我们可以将这个饼干j分配给孩子i,这个孩子会得到满足。你的目标是尽可能满足越多数量的孩子,并输出这个最大数值。示例1:输入:g=[1,2,3],s=[1,1]输出:1解释:
Java之弟
·
2024-02-05 03:00
LeetCode
#
贪心算法
leetcode
算法
数据结构
【
LeetCode
-简单】14. 最长公共前缀(详解)
题目地址:https://
leetcode
.cn/problems/longest-common-prefix/示例方法1:字符串截取比较-前缀由短边长(自己写的)思路前缀从短变长先让数组第一个字符串的前一个字母作为
丨康有为丨
·
2024-02-05 03:29
LeetCode刷题
leetcode
算法
java
LeetCode
--代码详解 1.两数之和
给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。你可以按任意顺序返回答案。示例1:输入:nums=[2,7,11,15],target=9输出:[0,1]解释:因为nums[0]+nums[1]==9,返回[0,1]。示例2:输入:num
Java之弟
·
2024-02-05 03:27
LeetCode
算法
leetcode
数据结构
【数据结构】链表OJ面试题(题库+解析)
力扣(
LeetCode
)官网-全球极客挚爱的技术成长平台思路:遍历整个表,访问每个表的值并且删除再将next的指针指向下一个节点此题比较简单,
CatShitK
·
2024-02-05 03:18
数据结构
数据结构
链表
c语言
算法
开发语言
c++
代码随想录算法训练营第三十九天| 62.不同路径、63. 不同路径 II
62.不同路径题目链接:力扣(
LeetCode
)官网-全球极客挚爱的技术成长平台解题思路:机器人每次只能向下或者向右移动一步。所以只需要考虑当前位置上方和左方元素的值,相加即可。
麦城稻香咖啡
·
2024-02-05 03:13
算法
代码随想录算法训练营第三十八天| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
509.斐波那契数题目链接:力扣(
LeetCode
)官网-全球极客挚爱的技术成长平台解题思路:无需思路classSolution{publicintfib(intn){if(n==0)return0;if
麦城稻香咖啡
·
2024-02-05 03:12
算法
【
LeetCode
】刷题总结 - 15. 三数之和
15.三数之和|
LeetCode
思路首先对nums进行排序,然后设置三个指针:left、mid、right:left从最左边开始,依次向后遍历每次固定住left后,就化为一个2sum问题:mid=left
yubinCloud
·
2024-02-05 03:06
LeetCode
leetcode
算法
【
Leetcode
】Given a non-negative integer numRows, generate the first numRows of Pascal's triangle.
Givenanon-negativeintegernumRows,generatethefirstnumRowsofPascal'striangle.classSolution(object):defgenerate(self,numRows):""":typenumRows:int:rtype:List[List[int]]"""ret=[[1],[1,1]]row=[1,1]ifnumRows
云端漫步_b5aa
·
2024-02-05 02:59
Leetcode
PHP题解--D24 476. Number Complement
476.NumberComplement题目链接476.NumberComplement题目分析给定一个数字,将他转换成二进制后,将0和1对调过来,把对调后的二进制再转换成十进制。返回该数字即可。思路题目描述得已经很清楚了。先用decbin转换成二进制,用str_replace把0和1对调过来。要注意对调的时候,不能直接对调。需要先把0换成除1之外的其他字符,最后再把他替换过来。因为str_rep
skys215
·
2024-02-05 02:29
[
LeetCode
] 22. Generate Parentheses(medium)
原题思路:利用DFS,搜索每一种情况,同时先加“(”后加")",保证()匹配正确。最近开始学习前端,尝试用js来写。constgenerate=function(res,content,left,right){if(left===0){res.push(content+')'.repeat(right));return;}if(left0){generate(res,content+'(',lef
弱花
·
2024-02-05 02:34
LeetCode
104. 二叉树的最大深度 | Python
104.二叉树的最大深度题目来源:力扣(
LeetCode
)https://
leetcode
-cn.com/problems/maximum-depth-of-binary-tree题目给定一个二叉树,找出其最大深度
大梦三千秋
·
2024-02-05 01:44
LeetCode
简单题:237. 删除链表中的节点(Python,C++,Java)
一.解法https://
leetcode
-cn.com/problems/delete-node-in-a-linked-list/要点:链表这题说的是在不知道前一个节点的情况下怎么删除当前节点,方法是将当前节点的值变为下一个节点的值
好莱坞守门员
·
2024-02-05 01:50
2023-04-03
LeetCode
:1053. 交换一次的先前排列
1053.交换一次的先前排列问题描述给你一个正整数数组arr(可能存在重复的元素),请你返回可在一次交换(交换两数字arr[i]和arr[j]的位置)后得到的、按字典序排列小于arr的最大排列。如果无法这么操作,就请返回原数组。示例输入:arr=[3,2,1]输出:[3,1,2]解释:交换2和1输入:arr=[1,1,5]输出:[1,1,5]解释:已经是最小排列输入:arr=[1,9,4,6,7]
alex很累
·
2024-02-05 01:07
python中[[]] * (n)和[[] for _ in range(n)]的区别
1、现象刷
leetcode
207的时候碰到一个坑,用[[]]*(n)初始化二维数组,逻辑是正确的,但是结果始终不对。
Smart_Maggie
·
2024-02-05 00:29
python
python
leetcode207
leetcode
-35.搜索插入位置
题目给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。请必须使用时间复杂度为O(logn)的算法。示例1:输入:nums=[1,3,5,6],target=5输出:2示例2:输入:nums=[1,3,5,6],target=2输出:1示例3:输入:nums=[1,3,5,6],target=7输出:4提示:1>>1;intmid
续写少年!
·
2024-02-05 00:56
蓝桥
leetcode
算法
Java
leetcode
-34.在排序数组中查找元素的第一个和最后一个位置
题目:给你一个按照非递减顺序排列的整数数组nums,和一个目标值target。请你找出给定目标值在数组中的开始位置和结束位置。如果数组中不存在目标值target,返回[-1,-1]。你必须设计并实现时间复杂度为O(logn)的算法解决此问题。示例1:输入:nums=[5,7,7,8,8,10],target=8输出:[3,4]示例2:输入:nums=[5,7,7,8,8,10],target=6输
续写少年!
·
2024-02-05 00:26
算法入门
蓝桥
leetcode
算法
数据结构
Leetcode
刷题笔记题解(C++):200. 岛屿数量
思路:利用深度优先搜索的思路来查找1身边的1,并且遍历之后进行0替换防止重复dfs,代码如下所示classSolution{public:intnumIslands(vector>&grid){introw=grid.size();intcol=grid[0].size();intnumoflands=0;//从第一行开始遍历,是岛屿则进行周围深度优先搜索for(intr=0;r>&grid,in
Demo.demo
·
2024-02-05 00:48
Leetcode算法题解
leetcode
笔记
c++
Leetcode
刷题笔记题解(C++):1863. 找出所有子集的异或总和再求和
思路如下:递归思路,依次遍历数组中的数,当前数要不要选择像二叉树一样去遍历如下图所示00(选5)5(不选5)0101060606060+6+1+7+5+3+4+2=28classSolution{public:intres=0;intn=0;intsubsetXORSum(vector&nums){n=nums.size();dfs(nums,0,0);returnres;}voiddfs(vec
Demo.demo
·
2024-02-05 00:48
Leetcode算法题解
leetcode
笔记
c++
Leetcode
刷题笔记题解(C++):66. 加一
思路:分为两种情况1.没有进位,直接+完就完,比如46+1=472.有进位而且还需要扩展一位,比如99+1=100代码如下:classSolution{public:vectorplusOne(vector&digits){intjinwei=1;for(inti=digits.size()-1;i>=0;i--){inttemp=digits[i];digits[i]=(temp+jinwei)
Demo.demo
·
2024-02-05 00:17
Leetcode算法题解
c++
leetcode
数据结构
Leetcode
刷题笔记题解(C++):6. Z 字形变换
思路:根据每个字符的下标来确定它在哪一行,然后生产新的字符串即可代码如下:classSolution{public:stringconvert(strings,intnumRows){intsize=s.length();//行数取定义行数,如果字符串的长度小于行数的话则取字符串长度numRows=min(numRows,size);//如果字符串的长度为1或者行数为1时,直接输出原字符串if(n
Demo.demo
·
2024-02-05 00:17
Leetcode算法题解
字符串
c++
leetcode
算法
Leetcode
刷题笔记题解(C++):18. 四数之和
思路:在三数之和的基础上加一层循环即可,注意跳过相等的元素。代码如下,思路也可以看看我的注释:classSolution{public:vector>fourSum(vector&nums,inttarget){//先从小到大进行排序sort(nums.begin(),nums.end());//存放结果vector>result;//数组大小intsize=nums.size();//选择第一个
Demo.demo
·
2024-02-05 00:17
Leetcode算法题解
c++
算法
leetcode
数据结构
Leetcode
刷题笔记题解(C++):LCR 016.无重复字符的最长子串
思路:利用滑动窗口的思想,用起始位置startindex和curlength来记录这个滑动窗口的大小,并且得出最长距离;利用哈希表来判断在滑动窗口中是否存在重复字符,代码如下所示:classSolution{public:intlengthOfLongestSubstring(strings){//如果为空字符串,则返回0if(s.length()==0)return0;intmaxlength=
Demo.demo
·
2024-02-05 00:17
Leetcode算法题解
leetcode
笔记
c++
Leetcode
刷题笔记题解(C++):51. N皇后
思路:递归回溯符合规则:左上方(斜),上方(列),右上方(斜)都没有放置Q从第一行找位置,在第一行中遍历找位置,如果符合要求则放置皇后进入到下一行或者不放皇后看下一个位置如果最后行数=要求的n,则得到结果,大概思路图:(4皇后为例)看图大概能看懂的吧,几乎把每一种结果都试了,最后行数=n的话则为结果,剪枝的条件是符合上面那个规则代码如下:classSolution{public:vector>so
Demo.demo
·
2024-02-05 00:47
剪枝
leetcode
c++
N皇后问题
递归回溯
Leetcode
刷题笔记题解(C++):94. 二叉树的中序遍历
思路:利用栈做辅助来写算法,具体流程可见下图:帮助理解classSolution{public:vectorinorderTraversal(TreeNode*root){vectorres;stacks;while(root||!s.empty()){if(root){s.push(root);root=root->left;}else{root=s.top();res.push_back(ro
Demo.demo
·
2024-02-05 00:46
Leetcode算法题解
c++
算法
leetcode
二叉树
栈
Leetcode
刷题笔记题解(C++):1306. 跳跃游戏 III
利用BFS的思路,注意标记已经走过的下标,还有两种跳跃的情况向前走或者向后走。代码如下:classSolution{public:boolcanReach(vector&arr,intstart){if(arr[start]==0)returntrue;queueq;vectorused(arr.size());q.push(start);used[start]=true;while(!q.emp
Demo.demo
·
2024-02-05 00:46
Leetcode算法题解
bfs
c++
leetcode
数据结构
算法
Leetcode
刷题笔记题解(C++):141. 环形链表
解决思路:常规做法就是利用辅助数据来记录遍历的节点,如果当前遍历的节点在辅助空间中存在即存在循环链表,否则没有存在循环链表。但是需要空间比较大。这里思路是用两个节点不同速度去遍历,一个走两步,一个走一步,在遍历不为空的情况下如果某次相遇则是回环链表。代码如下:/***Definitionforsingly-linkedlist.*structListNode{*intval;*ListNode*n
Demo.demo
·
2024-02-05 00:16
Leetcode算法题解
c++
leetcode
链表回环
Leetcode
刷题笔记题解(C++):739. 每日温度
###解题思路:利用栈来解决。注意的是栈中压入的下标的值首先压入0如果栈不为空且要压入的下标值i有T[i]>T[栈顶元素]则res[栈顶元素]=i-栈顶元素否则继续压栈,直到压完T中所有的数据为止。还要注意的是,开始对res全部赋值为0,这就对栈中的元素没弹出来的默认为0;这里附一下图吧,好理解一点。代码如下:classSolution{public:vectordailyTemperatures
Demo.demo
·
2024-02-05 00:16
Leetcode算法题解
c++
栈算法
leetcode
Leetcode
刷题笔记题解(C++):36. 有效的数独
思路一:暴力破解,两个二维数组记录行、列对应的数字出现的次数,比如rows[i][index]表示的数字index在i行出现的次数,三维数组记录每个块中对应数字出现的次数,比如boxes[i/3][j/3][index]表示的数字index在[i/3][j/3]个块中出现的次数,然后进行判断可以得出结果,超过1则不符合代码如下:classSolution{public:boolisValidSud
Demo.demo
·
2024-02-05 00:45
Leetcode算法题解
leetcode
笔记
c++
LeetCode
347 前 K 个高频元素
LeetCode
347前K个高频元素题目解题一:基于桶排序解题二:基于堆排序小顶堆大顶堆解题三:基于快速排序题目这题其实只是要先计数,剩下的只是排序,与
LeetCode
215数组中的第K个最大元素类似。
La vie est belle❤️
·
2024-02-05 00:32
刷题笔记
堆(优先队列)
快速排序
桶排序
哈希表
堆排序
leetcode
中二叉树递归遍历中的三种遍历方式实现
文章目录处理二叉树的解题思路1.
leetcode
144二叉树的前序遍历解题方法复杂度Code2.
leetcode
145二叉树的后序遍历解题方法复杂度Code3.
leetcode
94二叉树的中序遍历复杂度
IT民工小新
·
2024-02-05 00:01
#
我得leetcode之路
leetcode
深度优先
算法
leetcode
中二叉树迭代遍历中的三种遍历方式实现
文章目录144.二叉树的前序遍历思路解题方法复杂度Code2.94.二叉树的中序遍历思路复杂度Code145.二叉树的后序遍历思路Code144.二叉树的前序遍历Problem:144.二叉树的前序遍历思路迭代法实现二叉树的遍历,利用一个栈的取栈顶元素来实现访问节点对于迭代法来说,第一步就是访问几点,这里使用一个指针来实现节点的访问其次就是处理节点,在这里就是把节点从栈中弹出来之后,存储到结果数组
IT民工小新
·
2024-02-05 00:01
#
我得leetcode之路
leetcode
算法
LeetCode
347 前K个高频元素
1、数据结构哈希表frequency:用于统计各个不同数字的频率,数字为键,频率为对应的值。二维数组bucket:联想到之前的计数排序用到了桶,这里也可以用数组的下标表示频率,数组内容表示对应的值,使用二维数组是为了防止有频率相同的数字。2、首先对nums数组进行遍历,在frequency中对各个数字的频率进行统计。之后对frequency进行遍历,将出现频率为i的数字n存入数组,bucket[i
kkkkkkkkk777777777
·
2024-02-05 00:01
LeetCode
leetcode
leetcode
239. 滑动窗口最大值
Problem:239.滑动窗口最大值文章目录思路解题方法复杂度Code通过思路封装一个单调队列,让这个队列的对首就是队列中的最大值,每次入队的时候,如果入队元素大于对尾,就弹出元素,让队首就是元素的最大值解题方法定义一个Myque的单调队列,手动实现push,pop,getMaxValue三个函数push(intval):val是待入队的值,如果大于队尾就循环弹出队尾,最后才是把val从尾部加入
IT民工小新
·
2024-02-05 00:31
#
我得leetcode之路
leetcode
算法
职场和发展
leetcode
347 前 K 个高频元素
Problem:347.前K个高频元素文章目录思路解题方法复杂度Code通过思路遍历容器,储存到map中,之后遍历map,维护k个小根堆,然后存储到堆中最后存储到结果集中解题方法1.手动实现operator运算来实现小根堆,之后再定义优先队列priotity的时候,需要的是三个参数,分别为堆中存储的数据类型,用什么容器来存储堆中的元素2.统计元素的出现频率的时候,对于unordered_map来说
IT民工小新
·
2024-02-05 00:59
#
我得leetcode之路
leetcode
算法
2023-04-06
LeetCode
:负二进制转换
1017.负二进制转换问题描述给你一个整数n,以二进制字符串的形式返回该整数的负二进制(base-2)表示。示例输入:n=2输出:"110"解释:(-2)2+(-2)1=2输入:n=3输出:"111"解释:(-2)2+(-2)1+(-2)1=3输入:n=4输出:"100"解释:(-2)2=4解题思路先按照“十进制转二进制”对整数n进行处理;将“二进制”数转为“负二进制”数:在“负二进制”数中,偶数
alex很累
·
2024-02-04 23:43
上一页
49
50
51
52
53
54
55
56
下一页
按字母分类:
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
其他