找出第一次出现重复的字符
摘要:找出第一次出现重复的字符 import java.util.HashMap; public class Solution{ public static Character findRepeatString(String str){ Character repeatString = null; Map
阅读全文
posted @
2020-04-19 22:13
凌晨三点半的飞机
阅读(326)
推荐(0)
二分法查找
摘要:查找一个数组元素的下标。二分法适用于已经排好序的数组,定义两个变量,一个low,一个high,则mid=(low+high)/2 算法核心:如果 value==arr[mid],中间值正好等于要查找的值,则返回下标,return mid; 如果 value<arr[mid],要找的值小于中间的值,则
阅读全文
posted @
2020-04-18 08:55
凌晨三点半的飞机
阅读(163)
推荐(0)
剑指offer---二进制中1的个数
摘要:题目描述 输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。 public class Solution { public int NumberOf1(int n) { int count = 0; while(n !=0){ //将n的二进制表示与 0000 0000 0000 00
阅读全文
posted @
2020-04-14 22:10
凌晨三点半的飞机
阅读(122)
推荐(0)
剑指offer---矩形覆盖
摘要:题目描述 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? 比如n=3时,2*3的矩形块有3种覆盖方法: public class Solution { public int RectCover(int target)
阅读全文
posted @
2020-04-14 22:09
凌晨三点半的飞机
阅读(103)
推荐(0)
剑指offer---变态跳台阶
摘要:题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。 public class Solution { public int JumpFloorII(int target) { if(target<=0) return 0; if(t
阅读全文
posted @
2020-04-14 22:06
凌晨三点半的飞机
阅读(98)
推荐(0)
剑指offer---跳台阶
摘要:题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。 public class Solution { public int JumpFloor(int target) { if(target <= 0){ return -1
阅读全文
posted @
2020-04-14 22:03
凌晨三点半的飞机
阅读(108)
推荐(0)
剑指offer---斐波那契数列
摘要:题目描述 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0)。 n<=39 public class Solution { public int Fibonacci(int n) { if(n == 0){ return 0; }else if(n=
阅读全文
posted @
2020-04-14 22:01
凌晨三点半的飞机
阅读(150)
推荐(0)
剑指offer---旋转数组的最小数字
摘要:题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。 import j
阅读全文
posted @
2020-04-14 21:57
凌晨三点半的飞机
阅读(111)
推荐(0)
剑指offer---用两个栈实现队列
摘要:题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。 import java.util.Stack; public class Solution { Stack<Integer> stack1 = new Stack<Integer>(); Stack<In
阅读全文
posted @
2020-04-14 21:53
凌晨三点半的飞机
阅读(96)
推荐(0)
剑指offer---重建二叉树
摘要:题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。 /** * Definition for binar
阅读全文
posted @
2020-04-14 21:51
凌晨三点半的飞机
阅读(101)
推荐(0)
剑指offer---从尾到头打印链表
摘要:题目描述 输入一个链表,按链表从尾到头的顺序返回一个ArrayList。 /** * public class ListNode { * int val; * ListNode next = null; * * ListNode(int val) { * this.val = val; * } *
阅读全文
posted @
2020-04-14 21:47
凌晨三点半的飞机
阅读(75)
推荐(0)
剑指offer---替换空格
摘要:题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy public class Solution { public String replaceSpace(StringBuffer st
阅读全文
posted @
2020-04-14 21:45
凌晨三点半的飞机
阅读(101)
推荐(0)
剑指offer---二维数组中的查找
摘要:题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。 public class Solution { public boolean Find(int
阅读全文
posted @
2020-04-14 21:42
凌晨三点半的飞机
阅读(97)
推荐(0)