自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

冷咖啡离开了杯垫,来到了博客

博采众长,搏出未来。

  • 博客(10)
  • 收藏
  • 关注

原创 数字在排序数组中出现的次数

题目描述统计一个数字在排序数组中出现的次数。思路分析为了让时间复杂度较低,考虑用二分查找。分别用两次二分查找,找到目标值第一次出现时的下标和最后一次出现时的下标。注意边界条件。(如:目标值只在数组的首或尾出现了1次)# -*- coding:utf-8 -*-class Solution: def GetNumberOfK(self, data, k): ...

2019-01-25 13:45:33 124

原创 滑动窗口的最大值

题目描述给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值。例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}; 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,...

2019-01-24 21:10:04 114

原创 判断平衡二叉树

题目描述输入一棵二叉树,判断该二叉树是否是平衡二叉树。思路分析平衡二叉树要求左子树与右子树的高度之差的绝对值不大于1,左、右子树同样满足上述要求。需要在求取二叉树的高度的基础上稍加改动。二叉树的高度通常采用先序遍历的递归方式,递归的输入从根结点开始到左右子树直到叶子结点停止,递归的输出则是从叶子结点开始递归返回子树的高度,直到最后返回整棵树的高度。因此只需要在计算高度后加一个对左右子树...

2019-01-24 15:53:17 133

原创 二叉搜索树的后序遍历

题目描述输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。思路分析二叉搜索树的左子树的结点值小于根结点值,右子树的结点值大于根节点的值,且左右子树同样符合上述条件。后序遍历序列的最后一个数是根结点的值,从左向右扫描数组,直到找到比根节点值大的数为止,此时指针位置i 将数列分为左右两部分,分别表示左、...

2019-01-24 15:05:17 120

原创 树的子结构

题目描述输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)思路分析主函数从A的根结点开始遍历,当遍历到结点a时,若a与B的根结点值相同,调用一个子函数来判断以a为根结点的树是否包含B树,若包含,返回True,若不包含,继续遍历A的剩余结点,重复上述操作。子函数采用先序遍历对两个树的结点逐一比较根结点的值是否相等,若相等,继续遍历比较,若不相等,返...

2019-01-24 11:28:21 108

原创 数据流中的中位数

题目描述如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。我们使用Insert()方法读取数据流,使用GetMedian()方法获取当前读取数据的中位数。思路分析任务分为两部分:建立一种数据结构,当插入新数据时,维持这个数据结构。 随时获取当前数...

2019-01-23 23:10:13 228

原创 序列化二叉树

题目描述请实现两个函数,分别用来序列化和反序列化二叉树思路序列化时:先根序遍历,None要用特殊符号‘#’表示,否则不能反序列化。例如,如下图所示的二叉树序列化为1,2,4,#,#,5,7,#,#,#,3,#,6,#,#反序列化时:还是利用先序遍历,碰到‘#’返回None。# -# -*- coding:utf-8 -*-# class TreeNode:# ...

2019-01-23 20:52:17 143

原创 把二叉树打印成多行

题目描述从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。思路在宽度优先遍历的基础上,需要记录二叉树每行的结点个数,每一行打印成一个列表,最后的结果是一个二维列表。宽度优先遍历过程采用队列完成。下面分析如何记录每行的个数:用变量toPrint记录当前层需要打印的结点个数,nextLevel记录下一层需要打印的个数,当toPrint变为0时,将nextLevel的值赋给...

2019-01-23 19:53:57 129

原创 连续子数组的最大和

题目:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。给一个数组,返回它的最大连续子序列的和(子向量的长度至少是1)。思路:在遍历数组的同时,设置两个变量,curSum用来...

2019-01-22 20:15:58 141

原创 数组中重复的数字

题目:在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。1. 可修改数组的方法,时间复杂度O(n),空间复杂度O(1)思路:长度为n的数组,每个数字都在0-n-1范围内。从头开...

2019-01-22 11:12:42 191 2

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除