07 2019 档案
摘要:题目描述 我们可以用 的小矩形横着或者竖着去覆盖更大的矩形。请问用 的小矩形无重叠地覆盖一个 的大矩形,总共有多少种方法?。 解题思路 n=1 只有横放一个矩形一种解决办法 n=2 有横放一个矩形,竖放两个矩形两种解决办法 n=3 n=2的基础上加1个横向,n=1的基础上加2个竖向 n=4 n=3的
阅读全文
摘要:题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。 解题思路 1.根据斐波那契数列公式拓展发现跳到第N个台阶最后一跳有N 1种可能(有可能从第一个台阶到第N 1个台阶) 所以F(n) = F(n 1) + F(n 2)+...+F
阅读全文
摘要:题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。 问题分析 设f(n)表示青蛙跳上n级台阶的跳法数。当只有一个台阶时, 即n = 1时, 只有1中跳法; 当n = 2时,有两种跳法; 当n = 3 时,有3种跳法; 当n
阅读全文
摘要:题目描述 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0)。 n 运行时间:1287ms 占用内存:9572k 解法二: 解法一的坏处就是重复的调用次数太多,所以要想办法把重 复的计算消掉,我们可以把已经得到的结果保存起来,供下次计算使用。 jav
阅读全文
摘要:题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的 一个旋转 ,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。 思路与实
阅读全文
摘要:题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。 思路与实现
阅读全文
摘要:题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。 思路与实现 前序遍历的第一个值为根节点的值,使用这个
阅读全文
摘要:题目描述 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList。 一般是不破坏链表结构 思路与实现 直接用栈存储就好了
阅读全文
摘要:题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。 思路与实现 解法: 先遍历一遍字符串,这样就能统计出字符串中空格的总数,并可以由此计算出替换之后的字符串长度。 每替换一个空格,长
阅读全文
摘要:题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。 解法一 利用二位数组有序的特性,首先选取数组中右上角的数字。如果该数字等于要查找的数字,查找过程
阅读全文
摘要:题目 Given an array A of non negative integers, return an array consisting of all the even elements of A, followed by all the odd elements of A. You may
阅读全文
摘要:"题目" 给定一个范围在 1 ≤ a[i] ≤ n ( n = 数组大小 ) 的 整型数组,数组中的元素一些出现了两次,另一些只出现一次。 找到所有在 [1, n] 范围之间没有出现在数组中的数字。 您能在不使用额外空间且时间复杂度为O(n)的情况下完成这个任务吗? 你可以假定返回的数组不算在额外空
阅读全文
摘要:用 来做同步处理时,锁的获取和释放都是隐式的,实现的原理是通过编译后加上不同的机器指令来实现。 而 就是一个普通的类,它是基于 来实现的。 是一个 重入锁 :一个线程获得了锁之后仍然可以 反复 的加锁,不会出现自己阻塞自己的情况。 是 并发包里实现锁、同步的一个重要的基础框架。 锁类型 Reentr
阅读全文