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
剑指offer算法详解
2021-09-23
IT1.LeetCode力扣:在排序数组中查找数字I2021-09-23(
剑指Offer
53-I.在排序数组中查找数字I)2.《
剑指offer
》:p257~p265英语1.墨墨背单词:复习50个单词
幸福大黑鸭
·
2024-02-07 21:35
剑指offer
第二版(PDF+源码) 百度云
链接:https://pan.baidu.com/s/1b6ZxVIBvjPfKifToh_h26Q密码:6t76https://github.com/zhedahht/ChineseCodingInterviewAppendix(代码)
人大神成长记2
·
2024-02-07 11:08
剑☞offer
python_ACM模式《
剑指offer
刷题》二叉树2
题目:面试tips:面试官有可能问到:如果你需要频繁地查找第k小的值,你将如何优化算法?(见思路三)思路:思路一:二叉搜索树最大的特点就是中序遍历是递增的。因此最容易想到的是对二叉树进行中序遍历存入数组中,再遍历数组至第k个数,就是二叉树的第k小的数/节点。这样的时间复杂度就是O(N+K),空复为O(N)。显然不是最优。思路二:在思路一的基础上不采用数组,直接对二叉搜索树进行中序遍历,在遍历的过程
cuier520
·
2024-02-07 10:33
剑指offer练习
算法
[英雄星球七月集训LeetCode解题日报] 第14日 栈
[英雄星球七月集训LeetCode解题日报]第14日栈日报题目一、1614.括号的最大嵌套深度1.题目描述2.思路分析3.代码实现二、
剑指Offer
06.从尾到头打印链表1.题目描述2.思路分析3.代码实现三
七水shuliang
·
2024-02-07 09:53
英雄星球七月集训
今天开刷leetcode
leetcode
链表
算法
力扣题解:剑指 Offer 27. 二叉树的镜像
题目
剑指Offer
27.二叉树的镜像请完成一个函数,输入一个二叉树,该函数输出它的镜像。
胡矣
·
2024-02-07 04:41
算法
LeetCode
leetcode题解
力扣题解
链表排序
二叉树镜像
二叉树
力扣
剑指Offer
27.二叉树的镜像题解
题目链接:
剑指Offer
27.二叉树的镜像题目解析:所谓镜像是指如果左边是原二叉树,右边是镜像二叉树,那么向中间对折可以完全重合解题思路:所有结点的左右子树对换解题例子:镜像后的结果:步骤:1.将根节点左右子树交换
kong_and_white
·
2024-02-07 04:09
算法设计与分析
算法
二叉树
剑指offer
编程题—对称的二叉树
题目描述请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。解题思路:递归思想实现,首先分两种情况进行考虑:树为空,直接返回true;树不为空,则转去判断左子树和右子树是否对称,分以下两种情况进行讨论:a.左子树和右子树都为空,直接返回true;b.左子树和右子树都不为空,并且左子树和右子树根节点的值相等,递归判断左子树的左子树和右子树的右
零岁的我
·
2024-02-06 22:45
2021-09-02
IT1.LeetCode力扣:从上到下打印二叉树III2021-09-02(
剑指Offer
32-III.从上到下打印二叉树III)2.
幸福大黑鸭
·
2024-02-06 14:29
动态规划
算法详解
及经典例题
https://www.cnblogs.com/chihaoyuIsnotHere/p/10138087.html
breezeee
·
2024-02-06 08:04
Rete算法浅析
文章目录一、概述:二、
算法详解
: 术语解释: 进一步了解Rete算法: 算法详细描述: Rete网络内容解析: Rete网络创建流程分析: 运行时执行流程分析: Rete算法的特点
NarutoConanKing
·
2024-02-06 06:27
java
规则引擎
剑指Offer
:59-按之字形顺序打印二叉树
题目描述请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推。思路实现vector>res;if(!pRoot)returnres;queueq;q.push(pRoot);while(!q.empty()){intlen=q.size();vectortmp;for(inti=0;ival);if(root
jackmxp
·
2024-02-06 05:52
[
剑指offer
] 字符流中第一个不重复的字符
本文首发于我的个人博客:尾尾部落题目描述请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。解题思路用一个哈希表来存储每个字符及其出现的次数,另外用一个字符串s来保存字符流中字符的顺序。每次插入的时候,在字符串s中插入该字符,然后在哈希表中
繁著
·
2024-02-06 03:45
贪心
算法详解
目录用贪心法求解的问题应具有的性质:1.贪心选择性质:2、最优子结构性质:3、贪心法的一般求解过程问题一:求解畜栏保留问题。思路:代码:运行截图:问题二:求解区间相交问题。思路:代码:测试截图:问题三:哈夫曼树构造哈夫曼树:代码:运行截图:哈夫曼树加密:思路:代码:运行截图:用贪心法求解的问题应具有的性质:贪心法总是做出在当前看来最好的选择,这个局部最优选择仅依赖以前的决策,不依赖于以后的决策。由
平常心-辉
·
2024-02-06 01:43
算法设计与分析
贪心算法
算法
c++
2021-09-28
IT1.LeetCode力扣:平衡二叉树2021-09-28(
剑指Offer
55-II.平衡二叉树)2.《
剑指offer
》:p273~p275英语1.墨墨背单词:复习50个单词
幸福大黑鸭
·
2024-02-05 23:45
反转字符串II●
剑指Offer
05.替换空格● 151.翻转字符串里的单词●
剑指Offer
58-II.左旋转字符串
344.反转字符串。就头和尾相对移动交换就行。交换用swap()函数,也可以用中间量自己写。一个函数实现反转就是:voidreverse(string&s,intf,inte){if(f=s.size()||e>=s.size()){return;}for(inti=f;i=s.size()||e>=s.size()){return;}for(inti=f;i=0&&s[c]=='')c--;s.
孤馆深沉
·
2024-02-05 17:10
c++
算法
C++实现《数据结构与算法》相关算法--串
本文仅提供算法代码参考,相关
算法详解
请参考青岛大学王卓老师的视频课程:数据结构与算法基础(青岛大学-王卓)目录串相关算法实现定义标识符此部分为顺序表相关算法串的顺序储存
pljnb
·
2024-02-05 17:20
C++
数据结构
数据结构
c++
算法
两个队列实现一个栈
《
剑指offer
》面试题9(相关题目):两个队列实现一个栈。
打工这件小事
·
2024-02-05 12:38
[备战CSP-J]贪心
算法详解
2023年备考建议贪心思想是指在对问题求解时,总是做出在当前看来是最好的选择。也就是说,如果要得到整个问题的最优答案,那么每一步都要尽可能的得到最优的答案。首先初赛必然无法考察贪心的证明。聚焦在贪心的经典题型,又因为贪心算法,方便与其他知识点关联,比如结构体排序后贪心,比如二分答案里做贪心,所以往往代码量和思维度都适合放在压轴题的位置。解决初赛中的贪心问题,先要熟悉贪心的常见题型。常见题型最常见的
_L.Y.H._
·
2024-02-05 11:15
备战CSP
贪心算法
算法
c++
贪心算法
csp
剑指offer
offer03数组中的重复数字题目描述:找出数组中重复的数字。在一个长度为n的数组nums里的所有数字都在0~n-1的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。示例1:输入:[2,3,1,0,2,5,3]输出:2或3我的思路:一.用字典。存在的问题:①一开始字典并未赋值,所以不能用if(dic[nums[i]]!=null
RussellW0
·
2024-02-04 20:57
数据结构
c#
Unity3D 游戏中的自动寻路有怎样的
算法详解
前言Unity3D是一款非常流行的游戏引擎,它的自动寻路功能可以使游戏角色在场景中自动找到最短路径并前往目标位置。本文将详细介绍Unity3D中自动寻路的算法原理以及代码实现。对惹,这里有一个游戏开发交流小组,希望大家可以点击进来一起交流一下开发经验呀在游戏开发中,自动寻路是非常重要的功能之一。它可以使游戏角色自动穿越复杂的地形、避开障碍物并找到最短路径。在Unity3D中,自动寻路功能是通过Na
Thomas_YXQ
·
2024-02-04 18:05
算法
游戏
unity
游戏引擎
OJ刷题:《
剑指offer
》之单身狗1、2 !(巧用位操作符,超详细讲解!)
目录1.单身狗11.1题目描述1.2排序寻找1.3巧用位操作符2.单身狗21.1题目描述1.2排序寻找1.3巧用位操作符不是每个人都能做自己想做的事,成为自己想成为的人。克心守己,律己则安!创作不易,宝子们!如果这篇文章对你们有帮助的话,别忘了给个免费的赞哟~1.单身狗11.1题目描述在一个整型数组中,只有一个数字出现一次,其他数组都是成对出现的,请找出那个只出现一次的数字。例如:数组中有:123
秋风起,再归来~
·
2024-02-04 16:18
初阶C语言刷题
算法
leetcode刷题(
剑指offer
)113.路径总和Ⅱ
113.路径总和Ⅱ给你二叉树的根节点root和一个整数目标和targetSum,找出所有从根节点到叶子节点路径总和等于给定目标和的路径。叶子节点是指没有子节点的节点。示例1:输入:root=[5,4,8,11,null,13,4,7,2,null,null,5,1],targetSum=22输出:[[5,4,11,2],[5,8,4,5]]示例2:输入:root=[1,2,3],targetSum
花里胡哨的菜只因
·
2024-02-04 13:57
leetcode
算法
职场和发展
leetcode刷题(
剑指offer
)138.随机链表的复制
138.随机链表的复制给你一个长度为n的链表,每个节点包含一个额外增加的随机指针random,该指针可以指向链表中的任何节点或空节点。构造这个链表的深拷贝。深拷贝应该正好由n个全新节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的next指针和random指针也都应指向复制链表中的新节点,并使原链表和复制链表中的这些指针能够表示相同的链表状态。复制链表中的指针都不应指向原链表中的节点。
花里胡哨的菜只因
·
2024-02-04 13:57
leetcode
链表
算法
leetcode刷题(
剑指offer
) 297.二叉树的序列化和反序列化
297.二叉树的序列化与反序列化序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据。请设计一个算法来实现二叉树的序列化与反序列化。这里不限定你的序列/反序列化算法执行逻辑,你只需要保证一个二叉树可以被序列化为一个字符串并且将这个字符串反序列化为原始的树结构。提示:输入输出格式与
花里胡哨的菜只因
·
2024-02-04 12:55
leetcode
linux
服务器
java经典面试题基础篇(持续更新算法)
文章目录一.基础算法1.1两数相加1.2无重复字符的最长子串1.3输出二叉树1.4
剑指Offer
04.二维数组中的查找1.5
剑指Offer
07.重建二叉树5.1思考:5.1.1前序遍历+中序遍历5.1.2
最难不过坚持丶渊洁
·
2024-02-04 12:33
Java体系
java
leetcode
链表
【转】机器学习--- 分类
算法详解
原文链接:http://blog.csdn.net/china1000/article/details/48597469感觉狼厂有些把机器学习和数据挖掘神话了,机器学习、数据挖掘的能力其实是有边界的。机器学习、数据挖掘永远是给大公司的业务锦上添花的东西,它可以帮助公司赚更多的钱,却不能帮助公司在与其他公司的竞争中取得领先优势,所以小公司招聘数据挖掘/机器学习不是为了装逼就是在自寻死路。可是相比JA
奔狼的春晓
·
2024-02-04 11:42
转载
机器学习
算法
数据挖掘
java数据结构与算法刷题-----LeetCode15. 三数之和
java数据结构与算法刷题目录(
剑指Offer
、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article
殷丿grd_志鹏
·
2024-02-04 08:53
算法
java
算法
leetcode
链表
[
剑指offer
] 不用加减乘除做加法
本文首发于我的个人博客:尾尾部落题目描述写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。解题思路用位运算来实现。step1:进行异或运算,计算两个数各个位置上的相加,不考虑进位;step2:进行位与运算,然后左移一位,计算进位值;step3:把异或运算的结果赋给num1,把进位值赋给num2,依此循环,进位值为空的时候结束循环,num1就是两数之和。参考代码publi
繁著
·
2024-02-04 03:59
Leetcode-3--递归、DFS、回溯
Leetcode--回溯、进制运算递归24两两交换链表143重排链表98验证二叉搜索树1796不同的二叉搜索树二叉树展开成链表回溯22括号生成39组合总和40组合总和216组合总和46排列47全排列⭐️
剑指
NKidult
·
2024-02-03 23:20
Leetcode
终于结束年前算法篇的计划了!!!
花了差不多一个月终于在年前刷完了:代码随想录+
剑指offer
||的所有题目了,这一路刷过来还是感觉不容易的最开始一天7到8题,到后面遇见熟练类型的题目一天可以写16到18题,个人感觉最难的部分还是贪心,
学心理学的猫
·
2024-02-03 21:25
经验分享
剑指offer
第二版(101——119)(全部完结)
剑指Offer
II101.分割等和子集boolcanPartition(vector&nums){intsum=0;for(inti=0;i=nums[i-1];j--){//cout&nums){intsum
学心理学的猫
·
2024-02-03 21:54
剑指向offer
算法
c++
开发语言
关于LeetCode测试正确一提交就错的解决方法
下图是错误的下图是正确的题目是:t
剑指Offer
II015.字符串中的所有变位词错误代码如下classSolution{public:vectorfindAnagrams(strings,stringp
学心理学的猫
·
2024-02-03 21:24
leetcode
算法
职场和发展
python_ACM模式《
剑指offer
刷题》链表4
题目:面试tips:询问是否需要判断环,可微调下方代码。思路:思路一:判断环是否存在:设定一快一慢指针,均从头节点出发,快指针一次走两步,慢指针一次走一步。若无环,则快指针会先到达空,返回False表示无环;若有环,则快慢指针必定相遇。前者无环快指针先到达空节点好理解,后者有环为什么快慢指针必定相遇呢?这里提供两种理解方式。理解①:理解②:设慢指针刚进入环的第一个节点时,快指针(此时必定在环中)与
cuier520
·
2024-02-03 21:30
剑指offer练习
链表
数据结构
python_ACM模式《
剑指offer
刷题》二叉树1
题目:面试tips:1.询问是否可以使用双端队列(看后面思路就可知为什么要问这个)思路:时复和空复都为O(n)思路一:利用双端队列。总体思想是利用二叉树层序遍历(二叉树的层序遍历就是用队列dq,且从左往右每一层存入队列中),但这里的双端队列使用在path中,即存储路径path时,遇到奇数列,从dq中读出来的节点进行尾插入path;遇到偶数列,从dq中读出来的节点进行头插入。例如:层序遍历对上述二叉
cuier520
·
2024-02-03 21:27
剑指offer练习
python
开发语言
剑指Offer
--从头到尾打印链表
输入一个链表,按链表值从尾到头的顺序返回一个ArrayList。#-*-coding:utf-8-*-#classListNode:#def__init__(self,x):#self.val=x#self.next=NoneclassSolution:#返回从尾部到头部的列表值序列,例如[1,2,3]defprintListFromTailToHead(self,listNode):#write
lazydecoder
·
2024-02-03 20:15
2021-10-13
IT1.LeetCode力扣:构建乘积数组2021-10-13(
剑指Offer
66.构建乘积数组)2.《
剑指offer
》:p312~p315英语1.墨墨背单词:复习50个单词
幸福大黑鸭
·
2024-02-03 19:44
限流
算法详解
一、什么是限流限流是指在高并发、大流量请求的情况下,限制新的流量对系统的访问,从而保证系统服务的安全性。限流可以应对:热点业务带来的突发请求;调用方bug导致的突发请求;恶意攻击请求二、为什么要分布式限流当应用为单点应用时,只要应用进行了限流,那么应用所依赖的各种服务也得到了保护。但线上的业务出于各种原因考虑,多是分布式系统,单点的限流仅能保护自身节点,但无法保护应用依赖的各种服务,并且在进行节点
crazyK.
·
2024-02-03 14:42
并发
限流算法
分布式
并发
【经典案例 | 骑士之旅】回溯算法解决经典国际象棋骑士之旅问题 | 详解Knight’s Tour Problem数学问题
阅读本文需要您先掌握顺序表的基本操作,具体可参阅我的往期博客:【C++数据结构|顺序表速通】使用顺序表完成简单的成绩管理系统.by.Qin3Yu本文所使用搜索方法实质为深度优先搜索(DFS),相关内容可参阅我的往期博客:【
算法详解
Qin3Yu
·
2024-02-03 14:22
经典案例详解
算法
dfs
数据结构
图搜索
图搜索算法
图论
【
算法详解
| DFS算法】深度优先搜索解走迷宫问题 | 深度优先图遍历
DFS算法by.Qin3Yu本文需要读者掌握结构体和栈的操作基础,完整代码将在文章末尾展示。特别声明:本文为了尽可能使用简单描述,以求简单明了,可能部分专有名词定义不准确。栈相关操作可以参考我的往期博文:【C++数据结构|栈速通】使用栈完成十进制数转二四八进制数.by.Qin3Yu文中所有代码使用C++举例,且默认已使用std命名空间:usingnamespacestd;概念速览什么是DFS算法?
Qin3Yu
·
2024-02-03 14:52
算法详解
算法
深度优先
dfs
图搜索
图论
图搜索算法
c++
【
算法详解
| 二分查找】详解二分查找 \ 折半查找高效搜索算法 | 顺序数组最快搜索算法 | 递归&循环解决二分查找问题
二分查找by.Qin3Yu本文需要读者掌握顺序表的操作基础,完整代码将在文章末尾展示。顺序表相关操作可以参考我的往期博文:【C++数据结构|顺序表速通】使用顺序表完成简单的成绩管理系统.by.Qin3Yu文中所有代码使用C++举例,且默认已使用部分头文件和std命名空间:#include#includeusingnamespacestd;概念速览二分查找概述二分查找算法属于搜索算法的一种。它是一种
Qin3Yu
·
2024-02-03 14:19
算法详解
算法
查找
二分查找
搜索
二分
数据结构
C++
leetcode刷题(
剑指offer
) 50.Pow(x, n)
50.Pow(x,n)实现pow(x,n),即计算x的整数n次幂函数(即,xn)。示例1:输入:x=2.00000,n=10输出:1024.00000示例2:输入:x=2.10000,n=3输出:9.26100示例3:输入:x=2.00000,n=-2输出:0.25000解释:2-2=1/22=1/4=0.25提示:-100.00。-104>=1;}returnres;}}
花里胡哨的菜只因
·
2024-02-03 03:05
leetcode
算法
职场和发展
leetcode刷题(
剑指offer
) 946.验证栈序列
946.验证栈序列给定pushed和popped两个序列,每个序列中的值都不重复,只有当它们可能是在最初空栈上进行的推入push和弹出pop操作序列的结果时,返回true;否则,返回false。示例1:输入:pushed=[1,2,3,4,5],popped=[4,5,3,2,1]输出:true解释:我们可以按以下顺序执行:push(1),push(2),push(3),push(4),pop()
花里胡哨的菜只因
·
2024-02-03 03:05
leetcode
算法
职场和发展
leetcode刷题(
剑指offer
) 102.二叉树的层序遍历
102.二叉树的层序遍历给你二叉树的根节点root,返回其节点值的层序遍历。(即逐层地,从左到右访问所有节点)。示例1:输入:root=[3,9,20,null,null,15,7]输出:[[3],[9,20],[15,7]]示例2:输入:root=[1]输出:[[1]]示例3:输入:root=[]输出:[]提示:树中节点数目在范围[0,2000]内-1000>levelOrder(TreeNod
花里胡哨的菜只因
·
2024-02-03 03:05
leetcode
linux
算法
leetcode刷题(
剑指offer
) 155.最小栈
155.最小栈设计一个支持push,pop,top操作,并能在常数时间内检索到最小元素的栈。实现MinStack类:MinStack()初始化堆栈对象。voidpush(intval)将元素val推入堆栈。voidpop()删除堆栈顶部的元素。inttop()获取堆栈顶部的元素。intgetMin()获取堆栈中的最小元素。示例1:输入:["MinStack","push","push","push
花里胡哨的菜只因
·
2024-02-03 03:35
leetcode
linux
算法
leetcode刷题(
剑指offer
) 509.斐波那契数
509.斐波那契数斐波那契数(通常用F(n)表示)形成的序列称为斐波那契数列。该数列由0和1开始,后面的每一项数字都是前面两项数字的和。也就是:F(0)=0,F(1)=1F(n)=F(n-1)+F(n-2),其中n>1给定n,请计算F(n)。示例1:输入:n=2输出:1解释:F(2)=F(1)+F(0)=1+0=1示例2:输入:n=3输出:2解释:F(3)=F(2)+F(1)=1+1=2示例3:输
花里胡哨的菜只因
·
2024-02-03 03:34
leetcode
算法
职场和发展
leetcode刷题(
剑指offer
) 103.二叉树的锯齿形层序遍历
103.二叉树的锯齿形层序遍历给你二叉树的根节点root,返回其节点值的锯齿形层序遍历。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。示例1:输入:root=[3,9,20,null,null,15,7]输出:[[3],[20,9],[15,7]]示例2:输入:root=[1]输出:[[1]]示例3:输入:root=[]输出:[]提示:树中节点数目在范围[0,2000]
花里胡哨的菜只因
·
2024-02-03 03:02
leetcode
linux
windows
算法学习——力扣刷题
本次所刷题以及答案的参考来自链接:https://leetcode-cn.com/leetbook/read/illustration-of-algorithm/50ywkd/.力扣刷题——
剑指Offer
菜鸟闯关记
·
2024-02-02 23:17
android
算法
leetcode
菜鸡的LeetCode刷题笔记-两个栈实现队列
文章目录前言1.基础知识1.1数据结构:栈1.1数据结构:队列2.解题思路一个栈实现插入,一个栈实现删除前言leetcode上,
剑指offer
,用两个栈实现队列:题目地址1.基础知识1.1数据结构:栈栈是一种数据结构
OneDAYL4
·
2024-02-02 21:31
力扣刷题-JAVA
leetcode
数据结构
java
[H数据结构] lc295. 数据流的中位数(对顶堆+技巧+思维+代码实现)
算法常用,
剑指offer
中也会出现,这个数据结构设计的十分巧妙!思路:中位数,实际上就是将数组分成有序
Ypuyu
·
2024-02-02 13:26
LeetCode
数据结构
redis
数据库
OJ刷题:《
剑指offer
》之左旋字符串!
目录1.题目描述2.方法一(元素一一挪)2.1算法解析2.2代码实现3.方法二(三次逆置)3.1算法解析3.2代码实现4.方法三(库方法)4.1算法解析4.2代码实现5.完结散花创作不易,宝子们!如果这篇文章对你们有帮助的话,别忘了给个免费的赞哟~1.题目描述https://www.nowcoder.com/share/jump/1889476041706625158356题目链接放这里啦~2.方
秋风起,再归来~
·
2024-02-02 09:22
java
算法
开发语言
上一页
1
2
3
4
5
6
7
8
下一页
按字母分类:
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
其他