自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(30)
  • 收藏
  • 关注

原创 Docker使用oracle数据库

1.下载oracle镜像docker pull store/oracle/database-enterprise:12.2.0.12.查看镜像docker images3.从下载的镜像创建并启动容器docker run -d -p 1521:1521 --name oracle store/oracle/database-enterprise:12.2.0.1这里把新建的容器命名为oracle,并且是做了-d的端口映射的。4.查看当前运行的容器docker ps5.进入已经启动的O

2020-08-16 22:05:45 402

原创 对称加密与非对称加密

对称加密简介:对称加密算法又称传统加密算法。加密和解密使用同一个密钥。加密解密过程:明文->密钥加密->密文,密文->密钥解密->明文。示例:密钥:X加密算法:每个字符+X明文:Hello密钥为 1时加密结果:Ifmmp密钥为 2时加密结果:Jgnnq优缺点:算法公开,计算量小,加密速度快,加密效率高双方使用相同的钥匙,安全性得不到保证注意事项:...

2020-04-15 23:20:54 562

原创 剑指offer(JS版本)-22-从上往下打印二叉树

题目描述:从上往下打印出二叉树的每个节点,同层节点从左至右打印。思路:利用一个队列存储二叉树的节点,以此树为例。先把8放进队列,此时队列不为空,出队一个值,就是8,把值push进数组,然后判断8有没有左右孩子,所以6进队列,然后10队列。此时队列不为空,出队一个值6,并push进数组,6有左右孩子,所以5进队列,7进队列。此时队列不为空,出队一个值是10,10进数组,10有左右孩子,9进...

2020-04-09 16:20:27 157

原创 剑指offer(JS版本)-21-栈的压入、弹出序列

题目描述:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)思路:借用一个辅助的栈,遍历压栈顺序,先讲第一个放入栈中,这里是1,然后判断栈顶元...

2020-04-09 15:56:49 91

原创 剑指offer(JS版本)-20-包含min函数的栈

题目描述:定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。注意:保证测试中不会当栈为空的时候,对栈调用pop()或者min()或者top()方法。思路:主要是min方法的实现,直接遍历栈,返回最小值即可。(注意方法的时间复杂度)代码实现:var stack = [];function push(node){ // wr...

2020-04-08 23:39:12 88

原创 剑指offer(JS版本)-19-顺时针打印矩阵

题目描述输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.思路:先定义好矩阵的四个角的坐标,从左上角开始打印,打印完一圈之后,将左上角的坐标向里移动一层、右下角的坐标也向里移...

2020-04-08 23:23:11 107

原创 剑指offer(JS版本)-18-二叉树的镜像

题目描述:操作给定的二叉树,将其变换为源二叉树的镜像。思路:定义一个中间替换变量,利用函数递归,遍历二叉树的左右子树,依次完成左右替换。代码实现:/* function TreeNode(x) { this.val = x; this.left = null; this.right = null;} */function Mirror(root){ ...

2020-04-08 21:41:02 113

原创 剑指offer(JS版本)-17-树的子结构

题目描述:输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)思路:1、当Tree1和Tree2都不为零的时候,才进行比较。否则直接返回false2、如果在Tree1中找到了和Tree2的根节点值相同的点,则以这个节点为起点,判断是否包含Tree2;如果没找到,则直接返回false。3、定义一个方法,将上述Tree1中的那个节点和Tree2作为参数,...

2020-04-08 21:25:33 109

原创 剑指offer(JS版本)-16-合并两个排序的链表

题目描述:输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。思路:使用函数递归思想,举例:var List1 = { val: 1, next:{ val: 3, next:{ val:5, next: null } }}v...

2020-04-07 21:33:31 103

原创 剑指offer(JS版本)-15-反转链表

题目描述:输入一个链表,反转链表后,输出新链表的表头。思路:遍历链表,将链表值存入数组,再次遍历链表,将第一个节点值改成数组最后一个元素,将第二个节点值改成数组倒数第二个元素…以此完成链表反转代码实现:/*function ListNode(x){ this.val = x; this.next = null;}*/function ReverseList(pHead...

2020-04-07 21:06:25 105

原创 剑指offer(JS版本)-14-链表中倒数第k个结点

题目描述:输入一个链表,输出该链表中倒数第k个结点。思路:遍历链表,将每个节点都放进一个数组中,返回数组倒数第k个元素即可代码实现:/*function ListNode(x){ this.val = x; this.next = null;}*/function FindKthToTail(head, k){ // write code here ...

2020-04-07 20:24:41 85

原创 剑指offer(JS版本)-13-调整数组顺序使奇数位于偶数前面

题目描述:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。思路:定义一个基数数组,一个偶数数组,遍历原数组,基数放进基数数组,偶数放进偶数数组,然后将两个数组拼接起来即可。代码实现:function reOrderArray(array){ // write ...

2020-04-07 20:02:03 87

原创 剑指offer(JS版本)-12-数值的整数次方

题目描述:给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。保证base和exponent不同时为0思路:直接调用Math.pow方法代码实现:function Power(base, exponent){ // write code here return Math.pow(base,exponent);...

2020-04-07 19:55:03 93

原创 剑指offer(JS版本)-11-二进制中1的个数

题目描述:输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。思路:先说一个规律,某二进制数减去1,会使这个二进制数最右边的1变成0,后面的数取反,举例:1000,减去1变成0111。1100,减去1变成1011。根据这个规律,使用按位与操作符(&),(某数)&(某数-1)如下:1111&1110=1110,1110&1101=1100,...

2020-04-07 19:49:37 149

原创 剑指offer(JS版本)-10-矩形覆盖

题目描述:我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?比如n=3时,2*3的矩形块有3种覆盖方法:思路:首先进行推算,假设大矩形是2×0,那么有0种方法假设大矩形是2×1,那么只有1种方法假设是2×2,那么有2种方法假设有2×3,那么有3种方法假设有2×4,那么有5种方法…观察规律,可发现其方法...

2020-04-07 17:32:15 82

原创 剑指offer(JS版本)-09-变态跳台阶

题目描述:一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。思路:假设有1级台阶,则有1种跳法假设有2级台阶,则有2种跳法假设有3级台阶,则有4种跳法假设有4级台阶,则有8种跳法…观察次序列:1,2,4,8,16…很明显为等比序列代码实现:function jumpFloorII(number){ // wr...

2020-04-07 17:30:41 124

原创 剑指offer(JS版本)-08-跳台阶

题目描述:一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。思路:首先进行推算,假设台阶数为1,则有1种跳法假设台阶数为2,则有2种跳法假设台阶数为3,则有3种跳法假设台阶数为4,则有5种跳法…观察此序列:1,2,3,5,8…为斐波那契数列代码实现:function jumpFloor(number){ ...

2020-04-07 17:28:40 76

原创 剑指offer(JS版本)-07-斐波那契数列

题目描述:大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0)。n<=39思路:斐波那契数列(从零开始):0,1,1,2,3,5,8…后一项为前两项的和,第一种实现方式可以用函数递归,但是此种方式时间复杂度过高,代码不能通过,则使用数组,每次push进数组的值是前两项的和,最后使用pop取出最后那个值即可代码实现:function ...

2020-04-07 17:25:16 91

原创 剑指offer(JS版本)-06-旋转数组的最小数字

题目描述:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。思路:其实旋转前和旋转后的数组,其组成元素相同只是顺序不同,所以直接遍历数组并找出最小值即可代码实现:...

2020-04-07 17:21:36 154

原创 理解JS模块化开发规范:CommonJS、AMD、CMD、ES6

CommonJS(用于Node环境)根据CommonJs规范,每个文件就是一个模块,有自己的作用域。在一个文件里面定义的变量、函数、类,都是私有的,对其他文件不可见,CommonJS规范加载模块是同步的,也就是说,加载完成才可以执行后面的操作,Node.js主要用于服务器编程,模块一般都是存在本地硬盘中,加载比较快,所以Node.js采用CommonJS规范。定义模块// module.js...

2020-04-02 00:06:14 203

原创 剑指offer(JS版本)-05-用两个栈实现队列

题目描述:用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。思路:定义两个栈,我们知道队列是后进先出的特点,当有两个栈时,用栈1负责Push,假如进栈序列是{1,2},那么栈1里,2就是栈顶,1是栈底,再把栈1的元素放入栈2中,此时栈2中的序列则变成了1是栈顶,2是栈底,此时调用Push方法,则2先出来,则实现了队列后进先出的特点注意:在栈2有元素的时候,...

2020-03-22 15:01:47 108

原创 剑指offer(JS版本)-04-重建二叉树

题目描述:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。思路:我们知道前序遍历序列第一个值就是根节点,而在中序序列中,此根节点左边的序列都属于左子树,右边的值都属于右子树,例如:前序:{1,2,4,7,...

2020-03-22 14:37:47 115

原创 剑指offer(JS版本)-03-从尾到头打印链表

思路:遍历链表,将链表的值存储于数组之中,再调用reverse方法将数组反向即可;代码:/*function ListNode(x){ this.val = x; this.next = null;}*/function printListFromTailToHead(head){ // write code here var ArrayList = []...

2020-03-22 14:10:46 80

原创 剑指offer(JS版本)-02-替换空格

思路:直接调用replace,配合正则表达式全局匹配,将空格替换为"%20";代码:function replaceSpace(str){ // write code here var newStr = ""; newStr = str.replace(/ /g,"%20"); return newStr;}...

2020-03-22 13:55:10 111

原创 剑指offer(JS版本)-01-二维数组中的查找

思路:和右上角(第一行最后一个数)的数开始比较,如果目标数比它大,那么从这一行向左移一位,如果目标数比它小,那么换到下一行,直到找到目标值。代码:function Find(target, array){ // write code here var flag = false; var lines = array.length; var cols = arr...

2020-03-22 13:44:51 126

原创 在腾讯云上部署vue前后端分离项目

1、购买云服务器我使用的腾讯云,通过学生身份认证白嫖了15天的试用。。。操作系统为Linux的cent OS7关于如何购买并配置云服务器,可以参照此篇官方文档快速配置 Linux 云服务器2、配置云服务器的环境我的本地项目用到了node,mysql数据库,所以就要在云服务器上也把这些环境给配置好,首先是配置node环境:1、执行以下命令,下载 Node.js Linux 64位二进制...

2020-02-17 20:22:20 1896

原创 在腾讯云上部署静态网页

通过Nginx部署静态网站搭建静态网站,首先需要部署环境。通过 Nginx 部署 HTTP 静态服务在 CentOS 上,可直接使用 yum 来安装 Nginxyum install nginx -y安装完成后,使用 nginx 命令启动 Nginx:nginx访问 http://你服务器的域名,例如http:192.168.1.1, 可以看到 Nginx 的测试页面如果无法访问...

2020-02-17 00:03:58 3111

原创 vue双向绑定原理

通过Object.defineProperty实现数据劫持vue中双向绑定主要是通过数据劫持和发布订阅者模式实现的。1)数据劫持、vue是通过Object.defineProperty()来实现数据劫持,其中会有getter()和setter方法;当读取属性值时,就会触发getter()方法,在view中如果数据发生了变化,就会通过Object.defineProperty( )对属性设置一个...

2020-02-15 15:15:39 91

原创 使用phpStudy时mysql服务无法启动

之前安装过mysql,所以最初判断是端口被占用,于是把phpStudy集成的mysql的端口号改了一下,发现还是不行于是暴力卸载之前的mysql,结果phpStudy这边的服务就开启成功了,,,what fuck??...

2019-12-26 16:44:41 484

原创 webpack学习中踩的坑

webpack4以上需要下载cli依赖这个就不说了,npm上面如果报错会提示下载此依赖在使用webpack打包bootstrap的时候,bootstrap的字体图标无效,但却不报错原因:bootstrap 4.x版本把icon分离出来作为一个单独的项目open-iconic,所以cnpm i bootstrap -S是还不够的。还需要在安装open-iconic项目。详见:[https:/...

2019-12-23 17:29:41 112

空空如也

空空如也

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

TA关注的人

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