算法
weixin_41838371
这个作者很懒,什么都没留下…
展开
-
剑指offer (02-05)
01. 构建单个实例:实现 Singleton 单例模式Python中的单例模式的几种实现方式的及优化4种单例模式04. 替换空格参考:https://github.com/Jack-Lee-Hiter/AlgorithmsByPython/blob/master/Target Offer/替换空格.pyhttps://blog.csdn.net/u012505432/article...转载 2019-06-10 14:50:15 · 51 阅读 · 0 评论 -
附加题 57-59
附加题 54-56面试题57:删除链表中重复的结点思路梳理面试题57:删除链表中重复的结点在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。例如,链表1->2->3->3->4->4->5 处理后为 1->2->5。思路梳理...转载 2019-05-31 10:16:02 · 154 阅读 · 0 评论 -
6.4 抽象建模能力
剑指offer 6.4 抽象建模能力面试题43:n个骰子的点数思路梳理面试题44:扑克牌的顺子思路梳理面试题45:圆圈中最后剩下的数字题目梳理解法一:创建环形链表解法二:寻找输出数字的规律参考:所有offer题目的LeetCode链接及python实现github Target offer面试题43:n个骰子的点数题目:把n个骰子扔在地上,所有骰子朝上一面的点数之和为s。输入n,打...转载 2019-05-29 15:14:50 · 221 阅读 · 0 评论 -
附加题 60-62
附加题 60-62面试题60:把二叉树打印成多行思路梳理面试题61:按之字形顺序打印二叉树思路梳理面试题60:把二叉树打印成多行从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。思路梳理新定义一个列表 level,保存每一层的非空节点,每一次循环,将每一层非空节点的值作为列表,存入结果中。需要定义一个临时变量,保存当前层的节点对,然后从节点对中挑选出非空节点存为下一层的 ...转载 2019-06-01 11:45:14 · 101 阅读 · 0 评论 -
6.5 发散思维能力
剑指offer 6.5 发散思维能力面试题46:求1+2+…+n思路梳理面试题47:不用加减乘除做加法思路梳理面试题48:不能被继承的类参考:所有offer题目的LeetCode链接及python实现github Target offer面试题46:求1+2+…+n题目:求1+2+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判...转载 2019-05-29 16:22:24 · 134 阅读 · 0 评论 -
第7章 两个面试案例
剑指offer 第7章 两个面试案例面试题49 把字符串转换成整数思路梳理面试题50:树中两个节点的最低公共祖先思路梳理迭代版本1递归版本迭代版本2—— 结果错误参考:所有offer题目的LeetCode链接及python实现github Target offer从基本功能、边界条件和错误处理等方面确保代码的完整性和鲁棒性;把大的问题分解成两个或者多个小问题再递归地解决小问题;...转载 2019-05-29 22:34:29 · 108 阅读 · 0 评论 -
附加题 63-65
附加题 63-65面试题63:二叉搜索树的第k个结点题目梳理面试题64:数据流中的中位数题目梳理方法一:二分插入方法二:使用最大、最小堆面试题63:二叉搜索树的第k个结点给定一棵二叉搜索树,请找出其中的第k小的结点。例如, (5,3,7,2,4,6,8)中,按结点数值大小顺序第三小结点的值为4。题目梳理取中序遍历结果的第k个元素即为所求。# Definition for a binary...转载 2019-06-03 12:00:40 · 101 阅读 · 0 评论 -
附加题 66-68
附加题 63-65面试题66:矩阵中的路径思路梳理(回溯法)面试题66:矩阵中的路径请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。如果一条路径经过了矩阵中的某一个格子,则之后不能再次进入这个格子。 例如 a b c e s f c s a d e e 这样的3 X 4 矩阵中...转载 2019-06-04 12:05:13 · 107 阅读 · 0 评论 -
动态规划:编辑距离
题目描述UNIX系统下有一个行编辑器ed,它每次只对一行文本做删除一个字符、插入一个字符或替换一个字符三种操作。例如某一行的内容是“ABC”,经过把第二个字符替换成“D”、删除第一个字符、末尾插入一个字符“B”,这三步操作后,内容就变成了“DCB”。即“ABC”变成“DCB”需要经过3步操作,我们称它们的编辑距离为3。现在给你两个任意字符串(不包含空格),请帮忙计算它们的最短编辑距离。输入描...转载 2019-06-04 21:59:18 · 266 阅读 · 2 评论 -
回溯法
确定一下两点:1。结束的条件2。当前状态如何转换为下一(系列)状态转载 2019-06-11 14:45:38 · 96 阅读 · 0 评论 -
贪心算法
贪心算法贪心选择性质问题的全局最优解是通过局部最优选择得到的。转载 2019-06-11 20:47:33 · 63 阅读 · 0 评论 -
热门智力题 过桥问题和倒水问题
热门智力题 过桥问题和倒水问题1. 过桥问题思路梳理2. 倒水问题思路梳理热门智力题 过桥问题和倒水问题)热门智力题 过桥问题和倒水问题1. 过桥问题在漆黑的夜里,四位旅行者来到了一座狭窄而且没有护栏的桥边。如果不借助手电筒的话,大家是无论如何也不敢过桥去的。不幸的是,四个人一共只带了一只手电筒,而桥窄得只够让两个人同时通过。如果各自单独过桥的话,四人所需要的时间分别是1,2,5,8分钟;...转载 2019-06-11 20:48:01 · 264 阅读 · 0 评论 -
BFS、DFS、TopK
广度优先搜索算法(Breadth-First-Search,BFS)BFS(GRAPH G, NODE I):主要分为三步:1. 节点出队;2. visit 该节点;3. 节点入队。定义一个数组 visited ,布尔型变量,保存节点的 访问情况;定义一个队列 Queue,记录当前已访问过、但是其邻接点未访问的节点。单源最短路径问题:在原代码的基础上,加一个记录路径长度的变量。深度优先...转载 2019-06-12 10:53:34 · 100 阅读 · 0 评论 -
最小生成树算法:Kruskal与Prime
Kruskal与Prime的区别Kruskal算法本质是贪心算法,而Prime算法是动态规划。其实两者都是贪心的思想,只不过考虑的角度不同:Prim算法从顶点的角度出发,每次选择距离当前节点最近的节点加入,直到所有节点都加入。Kruskal算法从边的角度出发,每次总是选择权重最小的边加入,直到加入n-1条边为止。(如果加入一条边后出现回路,skip这条边)。prim适合点多的稠密图,k...转载 2019-06-12 11:12:41 · 1394 阅读 · 1 评论 -
单源最短路径
Dijkstra算法 Floyd算法问题描述:给定一个有向无环图,找出某一节点作为起点,到达图中其余各点的最短路径。Dijkstra算法原理:以起始点为中心向外层层扩展,直到扩展到终点为止,使用了广度优先搜索解决赋权有向图的单源最短路径问题,算法最终得到一个最短路径树。时间复杂度为O(N^2)辅助变量:一个队列,保存当前已经加入的节点;映射数组:保存起点到每个节点的距离/加权路径长度...转载 2019-06-12 11:23:02 · 154 阅读 · 0 评论 -
贪心算法
贪心算法1 基本思想2 贪心算法产生优化解的条件贪心算法和动态规划的区别贪心算法的基本思路LeetCode 55 跳跃游戏1 基本思想从问题的某一个初始解出发,通过一系列的贪心选择-当前状态下的局部最优选择,逐步逼近给定的目标;从而达到全局最优 的选择。在每个阶段,都作出一个按照某个评价函数最优的决策,这个评价函数最优称为贪心准则(类似于动态规划的状态转移方程)2 贪心算法产生优化解的条件...转载 2019-06-27 16:45:49 · 584 阅读 · 0 评论 -
附加题 54-56
附加题 54-56面试题54:表示数值的字符串思路梳理面试题55:字符流中第一个不重复的字符思路梳理面试题56:链表中环的入口结点思路梳理面试题54:表示数值的字符串这道题的关键也在于讨论清楚情况,把所有可能出现的情况都考虑到。需要注意的是,指数E后面必须跟一个整数,不能没有数,也不能为小数。LeetCode 65思路梳理难点:有很多情况需要考虑class Solution(objec...转载 2019-05-30 22:29:55 · 96 阅读 · 0 评论 -
附加题 51-53
面试题51:数组中重复的数字题目:对于一个长度为n的数组里所有的数字都在0到n-1的范围内。查找重复数字。方法一首先对数组进行排序,然后遍历数组查找重复的数字,这样的时间复杂度为O(nlogn);或者建立一个哈希表,这样实在O(n)的时间查找到,但是空间复杂度O(n)。方法二**空间复杂度为O(1)**的算法如下,因为数字在0~n-1的范围内,那么如果数字没有重复,那么当数组排...转载 2019-05-30 12:03:01 · 92 阅读 · 0 评论 -
堆排序
堆排序1 概念2 堆排序原理详解2.1 最大堆调整——维持堆的性质2.2 创建最大堆(Build-Max-Heap)2.3 堆排序(Heap-Sort)3 复杂度分析4 稳定性1 概念堆,也叫 二叉堆,是一个数组,树的每个节点对应数组一个元素。堆排序是利用 堆进行排序的堆是一种完全二叉树:完全二叉树 是 一种除了最后一层之外的其他每一层都被完全填充,并且所有结点都保持向左对齐的树,向左对...原创 2019-05-09 21:42:40 · 288 阅读 · 0 评论 -
剑指offer_2.3.4 树
剑指offer 2.3.4 树2.3.4 树1 树的遍历06.01 二叉树的镜像/反转06.02 重建二叉树(LeetCode 105)题目:思路解析代码实现06.02 重建二叉树(LeetCode 106)题目:思路解析代码实现参考:所有offer题目的LeetCode链接及python实现github Target offer2.3.4 树1 树的遍历分类一:前序遍历:先访...转载 2019-05-22 18:04:57 · 73 阅读 · 0 评论 -
2.3.5 栈和队列
剑指offer 2.3.5 栈和队列 2.3.5 栈和队列1 基础知识2 用两个栈实现一个队列解题思路3 用两个队列实现一个栈解题思路参考:所有offer题目的LeetCode链接及python实现github Target offer2.3.5 栈和队列1 基础知识栈是一个不考虑排序的数据结构,我们需要**O(n)**时间才能找到栈中最大或者最小的元素。如果想要在O(1)时间...转载 2019-05-22 17:56:08 · 97 阅读 · 0 评论 -
算法学习经验
算法学习经验首先算法不是只拼智商的,是可以通过后天的刻意练习掌握的一种能力。刚上手的时候,难度上需要循序渐进,最好能够按算法分类来刷题。解题的时候,建议按这三个步骤来1,看懂题目2,分析,推导解法3,将思路转换为代码。在更细节方面,封装的思想也可使用在算法上面,可以极大地降低我们的心智负担,提升解题的效率。最后是要注意做题过程中的正反馈,确保自己能持续地做下去。...转载 2019-06-10 14:50:03 · 235 阅读 · 0 评论 -
归并排序(Merge Sort)
归并排序(Merge Sort)1 前言2 归并排序2.1 核心思想2.2 算法实现2.3 算法分析1 前言冒泡排序、插入排序、选择排序这三种算法的时间复杂度都为 O(n2)O(n^2)O(n2),只适合小规模的数据。归并排序(Merge Sort)的时间复杂度为 O(nlogn)O(nlogn)O(nlogn) ,用到了分治思想。2 归并排序2.1 核心思想如果要排序一个数组:先把...原创 2019-05-22 12:01:07 · 189 阅读 · 0 评论 -
2.4 算法和数据操作
剑指offer 2.4 算法和数据操作摘要2.4.1 查找和排序面试题8:旋转数组的最小数字思路分析2.4.2 递归和循环面试题9:斐波那契数列思路解析递归循环题目二:青蛙跳台阶思路解析本题扩展1:相关题目2:参考:所有offer题目的LeetCode链接及python实现github Target offer摘要很多算法都可以用递归和循环两种不同的方式实现。通常基于递归的实现方...转载 2019-05-22 21:07:53 · 120 阅读 · 0 评论 -
2.4.3 位运算
剑指offer 2.4.3 位运算概念面试题10:二进制中1的个数思路解析1 可能会引起死循环2 聪明:$n = n\&(n-1)$扩展题目1扩展题目2参考:所有offer题目的LeetCode链接及python实现github Target offer概念位运算是把数字用二进制表示之后,对每一位上0或者1的运算。总共只有五种运算:与、或、异或、左移和右移。左移运算符m...原创 2019-05-23 09:54:11 · 130 阅读 · 0 评论 -
树的前、中、后遍历
树的前、中、后遍历二叉树结构定义前序遍历递归写法非递归写法中序遍历递归写法非递归写法后序遍历递归写法非递归写法层次遍历首先想到是递归算法,写法简单;二叉树的非递归算法需要用到辅助栈二叉树结构定义class BinNode(): def __init__( self, val ): self.lchild = None self.rchild = Non...转载 2019-05-24 12:14:03 · 234 阅读 · 0 评论 -
3 高质量的代码 3.3 代码的完整性
剑指offer 3 高质量的代码摘要面试题11:数值的整数次方思路解析面试题12:打印1到最大的n位数思路解析参考:所有offer题目的LeetCode链接及python实现github Target offer摘要面试小提示:应聘者在写代码的时候,最好用完整的英文单词组合命名变量和函数,以便面试官能一眼读懂代码的意图。从功能测试、边界测试、负面测试3个方面设计测试用例,以保证...转载 2019-05-23 16:39:35 · 182 阅读 · 0 评论 -
5.3 时间效率与空间效率的平衡
剑指offer 5.3 时间效率与空间效率的平衡摘要面试题34:丑数思路梳理参考:所有offer题目的LeetCode链接及python实现github Target offer摘要以空间换时间:分配少量的辅助空间来保存计算的中间结果以提高时间效率;以时间换空间:在n个无序的元素里做查找操作,需要O(n)的时间。但如果我们把这些元素放进一个哈希表,那么在哈希表内就能实现O(1...转载 2019-05-24 17:31:53 · 589 阅读 · 0 评论 -
4.4 分解让复杂问题简单化
4.4 分解让复杂问题简单化面试题26:复杂链表的复制思路梳理方法一:两次遍历方法二:一次遍历+哈希表方法三:在原链表的基础上复制,然后拆分链表代码实现面试题27:二叉搜索树与双向链表思路梳理回顾中序遍历面试题28:字符串的排列思路梳理本题扩展:参考:所有offer题目的LeetCode链接及python实现github Target offer面试题26:复杂链表的复制题目:请实现...转载 2019-05-23 21:02:11 · 716 阅读 · 0 评论 -
第5章 优化时间和空间效率
剑指offer 第5章 优化时间和空间效率5.2 时间效率参考:所有offer题目的LeetCode链接及python实现github Target offer5.2 时间效率递归的本质是把一个大的复杂问题分解成两个或者多个小的简单的问题。如果小问题中有相互重叠的部分,那么直接用递归实现虽然代码显得很简洁,但时间效率可能会非常差。同样是查找,如果是顺序查找需要O(n)的时间;如...转载 2019-05-23 21:35:31 · 425 阅读 · 0 评论 -
第6章 面试中的各项能力
剑指offer 第6章 面试中的各项能力面试题38:数字在排序数组中出现的次数思路梳理参考:所有offer题目的LeetCode链接及python实现github Target offer面试题38:数字在排序数组中出现的次数题目:统计一个数字在排序数组中出现的次数。例如输入排序数组{1,2,3,3,3,3,4,5}和数字3,由于3在这个数组中出现了4次,因此输出4。思路梳理二...转载 2019-05-25 17:34:36 · 203 阅读 · 0 评论 -
快速排序(Quick Sort)
快速排序(Quick Sort)1 摘要2 算法细节2.1 算法思想2.2 算法实现2.3 与归并排序的对比1 摘要时间复杂度: 最好、平均O(nlogn)O(nlogn)O(nlogn);最坏O(n2)O(n^2)O(n2)空间复杂度: O(n)O(n)O(n)是否稳定: 不稳定2 算法细节2.1 算法思想如果要对数组区间 [p, r] 的数据进行排序,先选择其中任意一个数据作...转载 2019-05-22 16:08:58 · 141 阅读 · 0 评论 -
3 高质量的代码 3.4 代码的鲁棒性
剑指offer 3 高质量的代码3.4 代码的鲁棒性面试题15:链表中倒数第k个结点思路梳理相关题目:面试题16:反转链表代码:面试题17:合并两个排序的链表思路梳理面试题18:树的子结构思路梳理3.5 本章小结参考:所有offer题目的LeetCode链接及python实现github Target offer3.4 代码的鲁棒性面试题15:链表中倒数第k个结点题目:输入一个链表...转载 2019-05-23 11:41:34 · 185 阅读 · 0 评论 -
第4章 解决面试题的思路
剑指offer 4 解决面试题的思路4.2 画图让抽象问题形象化面试题19:二叉树的镜像面试题20:顺时针打印矩阵参考:所有offer题目的LeetCode链接及python实现github Target offer4.2 画图让抽象问题形象化面试题19:二叉树的镜像题目:请完成一个函数,输入一个二叉树,该函数输出它的镜像。先前序遍历这棵树的每个结点,如果遍历到的结点有子结点...转载 2019-05-23 17:53:19 · 156 阅读 · 0 评论