摘要: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。 思路:创建两个新的数组,分别把奇数偶数放到两个数组里面,然后再把数组放进去。 阅读全文
posted @ 2017-02-13 21:02 alittlecomputer 阅读(148) 评论(0) 推荐(0)
摘要: 给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。 思路: 使用循环求。 阅读全文
posted @ 2017-02-13 20:28 alittlecomputer 阅读(121) 评论(0) 推荐(0)
摘要: 输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。 思路: 1的二进制是 前面都是0,最后一位为1,也就是只有一个1,每次向左移位一下,使得flag的二进制表示中始终只有一个位为1,每次与n做位与操作,这样就相当于逐个检测n的每一位是否是1了。 阅读全文
posted @ 2017-02-13 20:19 alittlecomputer 阅读(886) 评论(0) 推荐(0)
摘要: 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? 思路:通过计算前几个得到是斐波那契数列。 1 public class Solution { 2 public int RectCover(int target) { 3 阅读全文
posted @ 2017-02-13 20:02 alittlecomputer 阅读(128) 评论(0) 推荐(0)
摘要: 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。 思路: 笔算前几个得到规律是2的n次方。 阅读全文
posted @ 2017-02-13 17:23 alittlecomputer 阅读(138) 评论(0) 推荐(0)
摘要: 跳台阶 一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。 思路: 这个就相当于斐波那契数列。 阅读全文
posted @ 2017-02-13 17:10 alittlecomputer 阅读(276) 评论(0) 推荐(0)
摘要: 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。 思路:使用for循环,进行叠加,时间复杂度会低一些。 阅读全文
posted @ 2017-02-13 16:50 alittlecomputer 阅读(161) 评论(0) 推荐(0)
摘要: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。 思路: 旋转之后的数组实际 阅读全文
posted @ 2017-02-13 16:25 alittlecomputer 阅读(181) 评论(0) 推荐(0)
摘要: 用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。 用两个栈实现一个队列的功能?要求给出算法和思路! <分析>: 入队:将元素进栈A 出队:判断栈B是否为空,如果为空,则将栈A中所有元素pop,并push进栈B,栈B出栈; 如果不为空,栈B直接出栈。 用两个队列实现 阅读全文
posted @ 2017-02-13 13:59 alittlecomputer 阅读(184) 评论(0) 推荐(0)
摘要: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。 思路:前序遍历的第一位是树的根节点,在中序遍历中找到树的根节点 阅读全文
posted @ 2017-02-13 13:44 alittlecomputer 阅读(155) 评论(0) 推荐(0)
摘要: 输入一个链表,从尾到头打印链表每个节点的值。 方法一:借助堆栈的“后进先出”实现 阅读全文
posted @ 2017-02-13 12:32 alittlecomputer 阅读(151) 评论(0) 推荐(0)
摘要: 请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。 思路一: 调用String的replaceAll方法 思路二: 问题1:替换字符串,是在原来的字符串上做替换,还是新开辟一个字符串做替换! 问题 阅读全文
posted @ 2017-02-13 12:22 alittlecomputer 阅读(242) 评论(0) 推荐(0)
摘要: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。 思路: 矩阵是有序的,从左下角来看,向上数字递减,向右数字递增, 因此从左下角开始查找,当要查找数字比左下角数字大时。右移 要查找数 阅读全文
posted @ 2017-02-13 09:53 alittlecomputer 阅读(171) 评论(0) 推荐(0)
摘要: 转自:http://www.cnblogs.com/liujichang/p/3150387.html 多线程有两种实现方法,分别是继承Thread类与实现Runnable接口 同步的实现方法有两种,分别是synchronized,wait与notify 先看一下java线程运行时各个阶段的运行状态 阅读全文
posted @ 2017-02-12 22:48 alittlecomputer 阅读(6263) 评论(0) 推荐(0)
摘要: 电脑MAC地址(Media Access Control) MAC地址是固化在网卡上串行EEPROM中的物理地址,通常有48位长。用来表示互联网上每一个站点的标识符,采用十六进制数表示。 任一网络设备(如网卡,路由器)一旦生产出来以后,其MAC地址永远唯一且不能由用户改变。 具体可以看知乎https 阅读全文
posted @ 2017-02-12 19:11 alittlecomputer 阅读(446) 评论(0) 推荐(0)