自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

毛凡的博客

生活有时候挺没劲的,但活着却挺有意思

  • 博客(148)
  • 问答 (3)
  • 收藏
  • 关注

原创 二叉搜索树的第k个结点

题目描述给定一颗二叉搜索树,请找出其中的第k大的结点。例如, 5 / \ 3 7 /\ /\ 2 4 6 8 中,按结点数值大小顺序第三个结点的值为4。思路:因为是二叉搜索树,所以可以用中序遍历的方式存储然后输出第k个结点,要注意为0和大于结点大小的K值;代码如下:import java.util.ArrayList;/*public class TreeNod

2016-08-10 14:45:19 1498

原创 数据流中的中位数

题目描述如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值。如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值。思路:主要是判断是奇数还是偶数 用按位与&去判别最后一位是1 还是 0 ,是0表示偶数,是1表示奇数代码如下:import java.util.Collections;im

2016-08-10 14:43:29 464

原创 把二叉树打印成多行

题目描述从上到下按层打印二叉树,同一层结点从左至右输出。每一层输出一行。代码如如下:import java.util.ArrayList;import java.util.ArrayList;import java.util.Queue;import java.util.LinkedList;/*public class TreeNode { int v

2016-08-09 15:59:09 561

原创 序列化反序列二叉树

题目描述请实现两个函数,分别用来序列化和反序列化二叉树思路:序列化的时候遇到null的结点就补充“#,” ,反序列化的时候先split(",");代码如下:/*public class TreeNode { int val = 0; TreeNode left = null; TreeNode right = null; publ

2016-08-09 15:58:06 485

原创 对称的二叉树

请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。思路:主要先判断根节点下面的两个左右子节点是否相等,然后再用递归判断左子树的左孩子和右子树的右孩子是否相等,还有左子树的右孩子和右子树的左孩子是否相等,如果在递归的过程中并不满足则返回false;代码如下:/*public class TreeNode { int v

2016-08-08 16:57:58 398

原创 按之字形顺序打印二叉树

import java.util.ArrayList;import java.util.Queue;import java.util.LinkedList;/*public class TreeNode {    int val = 0;    TreeNode left = null;    TreeNode right = null;    public

2016-08-08 16:55:45 490

原创 二叉树的下一个结点

题目描述给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。/*public class TreeLinkNode { int val; TreeLinkNode left = null; TreeLinkNode right = null; TreeLinkNode

2016-08-07 17:35:12 441 5

原创 删除链表中重复的结点

题目描述在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5代码如下:/* public class ListNode { int val; ListNode next = null; ListNode(int val) {

2016-08-07 17:33:41 1095 5

原创 链表中环的入口结点

题目描述一个链表中包含环,请找出该链表的环的入口结点。思路:设置两个引用 A和B 指向头,然后一个走一步,一个走两步,然后找到相等的结点,然后再另一个从头开始,分别都走一步最后相等的就是环的入口结点代码如下:/* public class ListNode { int val; ListNode next = null; ListNode

2016-08-06 20:02:48 292

原创 字符流中第一个不重复

题目描述请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。 输出描述:如果当前字符流没有存在出现一次的字符,返回#字符。思路:创建256个int大小的数组,然后分别++找出重复的代码如下:import java.util.Ar

2016-08-06 20:00:07 319

原创 表示数值的字符串

题目描述请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值。 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是思路:用字符串转换代码如下:public class Solution { public boolean is

2016-08-06 19:58:07 249

原创 数组中重复的数字

题目描述在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是重复的数字2或者3。思路:创建一个256的大小的数组,然后用循环找一下是否有重复的数字,然后用随机函数去输出一个即可否则为fals

2016-08-04 16:34:09 315

原创 把字符串转换成整数

题目描述将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。思路:设置两个标志位 一个tag 为1表示是正数,为0表示是负数,一个index,为‘+’则index是1,为‘-’则index是-1,什么都没index是0     再用一个result去接受所有的数,result  =result * 10 + aa;从第一个开始慢慢加起来,不过每次都要判断是否上下

2016-08-04 16:32:35 441

原创 求1+2+3+...+n

题目描述求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。思路:用递归(结束条件是n==0)和&&的方式代码如下:public class Solution { public int Sum_Solution(int n) { int sum = n;

2016-08-03 18:54:19 586

转载 Java集合类详解

Collection├List│├LinkedList│├ArrayList│└Vector│ └Stack└SetMap├Hashtable├HashMap└WeakHashMapCollection接口  Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Element

2016-08-01 21:09:05 171375 21

原创 复杂链表的复制

题目描述输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)思路:分三步 。 1.复制该链表的每一个结点到对应每个结点的后面。 2,将每个结点上的random结点复制给刚刚复制的结点,记住是random.next,3.拆分

2016-07-19 19:16:10 304

原创 二叉树中和为某一值的路径

题目描述输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。思路:用先序遍历递归的思想去实现,到最后叶节点如果不能的话就退回去一步到叶子结点的父节点。代码如下:import java.util.ArrayList;/**public class TreeNode {

2016-07-19 19:13:06 352

原创 二叉搜索树的后序遍历序列

题目描述输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。思路:因为是二叉搜索树,所以根节点的左子树小于右子树,可以根据这一点用非递归的方法求得,代码如下:public class Solution { public boolean VerifySquenceOfBST(

2016-07-18 21:03:33 248

原创 从上往下打印二叉树

题目描述从上往下打印出二叉树的每个节点,同层节点从左至右打印。思路:意思就是按层遍历然后放到一个list集合里面去,所以创建一个队列每次把一层的结点放进去,然后一个一个判别是否有left结点和right结点直到最后一排代码如下:import java.util.ArrayList;import java.util.Queue;import java.util.L

2016-07-18 21:01:36 1262

原创 栈的压入、弹出序列

题目描述输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)思路:因为是两个数组pushA 和popA ,所有创建一个stack,然后将p

2016-07-18 20:59:38 223

原创 包含min函数的栈

题目描述定义栈的数据结构,请在该类型中实现一个能够得到栈最小元素的min函数。思路:用一个栈去存储所有元素,然后一个一个去比较 将小的那个值放到变量min里面;代码如下:import java.util.Stack;import java.util.Iterator;public class Solution { Stack stack = new

2016-07-18 20:50:04 191

原创 顺时针打印矩阵

题目描述输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 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.思路:先找到横竖分别都是为多少然后1,从左到右,2.从上到下,3,从右到左,4,从下到上,在3 和 4的过程中比如在

2016-07-17 20:20:26 206

原创 二叉树的镜像

题目描述操作给定的二叉树,将其变换为源二叉树的镜像。 输入描述:二叉树的镜像定义:源二叉树 8 / \ 6 10 / \ / \ 5 7 9 11 镜像二叉树 8 / \ 10 6 / \ / \ 11 9 7

2016-07-17 20:11:26 199

原创 树的子结构

题目描述输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)思路:可以先判断A和B的父结点是不是一样的,如果一样进入递归分别判断左子树和右子树是不是一样,       如果A和B的父结点不一样的话,继续判断A的左子树的父结点和B结点是否相等然后继续递归判断,        如果A的左子树的父结点不一样则判断A的右子树的父结点和B

2016-07-17 20:05:59 193

原创 合并两个排序的链表

题目描述输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。思路:先创建一个头结点 head  ,head.val为-1,然后创建一个指向该头结点的指针pre,然后用if判断用pre去链接接下的结点代码如下:/*public class ListNode { int val; ListNode next =

2016-07-17 19:58:01 261

原创 反转链表

题目描述输入一个链表,反转链表后,输出链表的所有元素思路:用一个pre指向前一个结点 ,用 next指向当前结点 next = head.next; head.next = pre; pre = head; head = next;代码如下:/*public class ListNode { int val; ListNode next =

2016-07-17 19:55:31 213

原创 链表中倒数第k个结点

题目描述输入一个链表,输出该链表中倒数第k个结点。思路:倒数第k个结点,则表示是第n-k+1个结点代码如下:/*public class ListNode { int val; ListNode next = null; ListNode(int val) { this.val = val; }}*/publi

2016-07-16 18:53:13 195

原创 调整数组顺序使奇数位于偶数前面

题目描述输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变思路:用集合分别收集奇数和偶数然后再用数组保存代码如下:import java.util.ArrayList;import java.util.List;public class Sol

2016-07-16 18:52:07 203

原创 数值的整数次方

题目描述给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。思路:判断该整数的负数和正数情况代码如下:public class Solution { public double Power(double base, int exponent) { double sum = 1.0;

2016-07-16 18:50:48 180

原创 二进制中1的个数

题目描述输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。思路:1的二进制是 前面都是0,最后一位为1,也就是只有一个1,每次向左移位一下,使得flag的二进制表示中始终只有一个位为1,每次与n做位与操作,这样就相当于逐个检测n的每一位是否是1了。代码如下:public class Solution {public int NumberOf1(int n)

2016-07-16 17:45:04 342

原创 矩形覆盖

题目描述我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?思路:依旧是斐波那契数列2*n的大矩形,和n个2*1的小矩形其中target*2为大矩阵的大小有以下几种情形:1⃣️target 2⃣️target = 1大矩形为2*1,只有一种摆放方法,r

2016-07-16 17:42:53 288

原创 变态跳台阶

题目描述一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。思路:关于本题,前提是n个台阶会有一次n阶的跳法。分析如下:f(1) = 1f(2) = f(2-1) + f(2-2)         //f(2-2) 表示2阶一次跳2阶的次数。f(3) = f(3-1) + f(3-2)

2016-07-16 17:38:26 209

原创 跳台阶

题目描述一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。思路:对于本题,前提只有 一次 1阶或者2阶的跳法。a.如果两种跳法,1阶或者2阶,那么假定第一次跳的是一阶,那么剩下的是n-1个台阶,跳法是f(n-1);b.假定第一次跳的是2阶,那么剩下的是n-2个台阶,跳法是f(n-2)c.由a\b假设可以得出总跳

2016-07-16 17:36:31 255

原创 斐波那契数列

题目描述大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。n思路:用非递归的方法,即遍历的方法去实现斐波拉切数列代码如下:public class Solution { public int Fibonacci(int n) { int a =1; int b =1;

2016-07-16 17:35:13 268

原创 旋转数组的最小数字

题目描述把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。思路:管它啥旋转数据,反正找到最小的数就可以了,用冒泡循环就可以了然后输出第一个;代码如下:

2016-07-16 17:33:52 237

原创 用两个栈实现队列

题目描述用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。思路:用两个栈stack1和stack2去实现队列,先将所有数据倒入stack1中,这叫入队,然后出队的时候将所有东西倒入第二个栈stack2中然后stack2,.pop()出栈一个,然后又将stack2中的数据全部倒入到stack1中去即可完成两个栈来实现一个队列;代码如下

2016-07-16 17:32:20 215

原创 从尾到头打印链表

题目描述输入一个链表,从尾到头打印链表每个节点的值。 输入描述:输入为链表的表头输出描述:输出为需要打印的“新链表”的表头思路:创建一个栈stack将链表依次倒入然后再依次倒出就可以了;代码如下:/*** public class ListNode {* int val;* ListNode n

2016-07-16 17:28:40 214

原创 替换空格

题目描述请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。思路:\s表示空白字符也就是空格,制表符这些,至于最前面的\是用来转义第二个\的代码如下:public class Solution { public String replaceSpace(Str

2016-07-16 17:26:42 213

原创 二维数组中的查找

题目描述在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。思路:根据题目的意思来看,可以先从每一行的最后一个开始和该整数进行比较,不符合条件往下面一行最后一个进行比较,以此类推。代码如下:public class Solution { publ

2016-07-16 17:20:44 214

原创 用JQuery去实现单个表格中的td数据修改

JS代码如下:$(document).ready(function(){ var tds =$("td"); tds.click(tdclick);});function tdclick(){ var td =$(this); var tdtext =td.text(); td.html(""); var inputtext

2016-07-08 22:05:37 11152

空空如也

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

TA关注的人

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