《剑指Offer》-06查找与排序
发表于
|
分类于
算法
旋转数组的最小数字
题目描述
把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。
输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。
例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。
NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。
方法一:顺序遍历
1 | function minNumberInRotateArray(rotateArray) |
《剑指Offer》-05栈与队列
发表于
|
分类于
算法
用两个栈实现队列
题目描述
用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。
1 | var stack1=[], |
圣杯布局与双飞翼布局
发表于
|
分类于
布局
《剑指Offer》-04链表
发表于
|
分类于
算法
重建二叉树
题目描述
输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
1 | /* function TreeNode(x) { |
《剑指Offer》-03链表
发表于
|
分类于
算法
《剑指Offer》-02字符串
发表于
|
分类于
算法
《剑指Offer》-01数组
发表于
|
分类于
算法
二维数组中的查找
题目描述 【简单】
在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
1 | function Find(target, array) |
总结:根据数组的规律,可从数组的左下或右上角找起,根据大小的方向性,依次排除掉列或者行。或者暴力法解题。
JavaScript ES语法学习笔记(五)
发表于
|
分类于
ES
Callback(异步操作)
异步操作不会立马执行,优先同步操作
实际中应避免回调地狱
Promise then
promise就是为了解决“回调地狱”问题的,他可以优雅地处理异步操作
举个例子:
加载1.js,如果没有发生错误;
加载2.js,如果没有发生错误;
加载3.js,如果没有发生错误——做其他操作
1 | function loadScript (src) { |