Java--剑指offer(2)
6.把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。
a)使用ArrayList来存放元素
public class Solution { public static int minNumberArray(int[] array) { int min = array[0]; for(int i = 0; i < array.length; i++){ if(min > array[i]){ min = array[i]; } } return min; } public ArrayList minNumberInRotateArray(int [] array) { ArrayList list = new ArrayList(); int minNum = minNumberArray(array); int i; for(i=0; i < array.length; i++){ if(minNum == array[i]){ break; } } //把最小数和最小数之后的元素放入list for(int j = i; j < array.length; j++){ list.add(array[j]); } //把最小数前面的元素放入list for(int k = 0;k < i; k++){ list.add(array[k]); } return list; } }
b) 使用数组来存放旋转后的数组
public class Solution { public static int minNumberArray(int[] array) { int min = array[0]; for(int i = 0; i < array.length; i++){ if(min > array[i]){ min = array[i]; } } return min; } public int[] minNumberInRotateArray(int [] array) { int[] arr = new int[array.length]; int minNum = minNumberArray(array); int i; for(i=0; i < array.length; i++){ if(minNum == array[i]){ break; } } int l = 0; //把最小数和最小数之后的元素放入list for(int j = i; j < array.length; j++,l++){ arr[l] = array[j]; } //把最小数前面的元素放入list for(int k = 0;k < i; k++,l++){ arr[l] = array[k]; } return arr; } public static void main(String[] args) { Solution s = new Solution(); int[] arr1 = new int[]{3,4,5,1,2}; int[] arr2 = s.minNumberInRotateArray(arr1); for(int i = 0; i < arr2.length; i++){ System.out.print(arr2[i]); } } }
7.大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。n<=39。
a)题目中提示n的值小于等于39,所以我们可以定义一个长度为39的数组,这样就不会超出大小。还有使用数组存放斐波拉契数比使用方法递归的时间效率高很多。程序中没有判断输入的数字是否大于39,这个很简单。
public class Solution { public int Fibonacci(int n) { int flag; int[] arr = new int[39]; arr[0] = 1; arr[1] = 1; if(n<=0){ flag = 0; }else if(n == 1){ flag = 1; }else{ for(int i = 2; i < n; i++){ arr[i] = arr[i-1] + arr[i-2]; } flag = arr[n-1]; } return flag; } public static void main(String[] args) { Solution s = new Solution(); System.out.println(s.Fibonacci(20)); } }
b)还有一种方法就是使用递归,这一方法的代码十分简单,但是时间有点长,通过不了网上在线编译器的测试。
public class Solution { public int Fibonacci(int n) { int flag; if(n<=0){ flag = 0; }else if(n == 1){ flag = 1; }else{ flag = Fibonacci(n-1)+Fibonacci(n-2); } return flag; } public static void main(String[] args) { Solution s = new Solution(); System.out.println(s.Fibonacci(20)); } }
8.一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
a)这是一个斐波拉契数列问题
观察可以得出,当n等于1时为1,n等于2时为2,n等于3时为3,n等于4时为5,可以观察出当n大于2时,结果等于n-1的结果加上n-2的结果,所以直接可以使用递归来实现。
public class Solution { public int JumpFloor(int target) { if(target <= 0){ return -1; } else if(target == 1){ return 1; } else if(target == 2){ return 2; } else{ return (JumpFloor(target-1)+JumpFloor(target-2)); } } public static void main(String[] args) { Solution s = new Solution(); System.out.println(s.JumpFloor(3)); } }
9.一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
a)这一题的解题步骤和上一体类似,也是斐波拉契数列。
public class Solution { public int JumpFloor(int target) { if(target <= 0){ return -1; } else if(target == 1){ return 1; } else if(target == 2){ return 2; } else{ return (JumpFloor(target-1)+JumpFloor(target-2)); } } public static void main(String[] args) { Solution s = new Solution(); System.out.println(s.JumpFloor(3)); } }
10.我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?
a)这题和前面两题类似,下面直接给出代码
public class Solution { public int RectCover(int target) { if(target <= 0){ return 0; } else if(target == 1){ return 1; } else if(target == 2){ return 2; } else{ return RectCover(target-1)+RectCover(target-2); } } public static void main(String[] args) { Solution s = new Solution(); System.out.println(s.RectCover(4)); } }
Java--剑指offer(2)的更多相关文章
- 剑指Offer:面试题15——链表中倒数第k个结点(java实现)
问题描述 输入一个链表,输出该链表中倒数第k个结点.(尾结点是倒数第一个) 结点定义如下: public class ListNode { int val; ListNode next = null; ...
- 剑指offer编程题Java实现——面试题5从头到尾打印链表
题目描述* 剑指offer面试题5:从尾到头打印链表 输入一个链表的头结点,从尾到头打印出每个结点的值 解决方案一:首先遍历链表的节点后打印,典型的"后进先出",可以使用栈来实现这 ...
- 剑指offer面试题-Java版-持续更新
最近在用Java刷剑指offer(第二版)的面试题.书中原题的代码采用C++编写,有些题的初衷是为了考察C++的指针.模板等特性,这些题使用Java编写有些不合适.但多数题还是考察通用的算法.数据结构 ...
- 《剑指offer》全部题目-含Java实现
1.二维数组中的查找 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. publi ...
- 剑指Offer——Java实现栈和队列的互模拟操作
剑指Offer--Java实现栈和队列的互模拟操作 栈模拟队列 题目:JAVA实现用两个栈来实现一个队列,完成队列的Push和Pop操作.队列中的元素为int类型. 思路:其实就是把队列正常入 ...
- 剑指Offer——知识点储备-故障检测、性能调优与Java类加载机制
剑指Offer--知识点储备-故障检测.性能调优与Java类加载机制 故障检测.性能调优 用什么工具可以查出内存泄露 (1)MerroyAnalyzer:一个功能丰富的java堆转储文件分析工具,可以 ...
- 剑指Offer——知识点储备-Java基础
剑指Offer--知识点储备-Java基础 网址来源: http://www.nowcoder.com/discuss/5949?type=0&order=0&pos=4&pa ...
- 剑指offer面试题5 从头到尾打印链表(java)
注:(1)这里体现了java数据结构与C语言的不同之处 (2)栈的操作直接利用stack进行 package com.xsf.SordForOffer; import java.util.Stack; ...
- 剑指offer面试题4 替换空格(java)
注:利用java中stringBuilder,append,length方法很方便的解决字符串问题 /* * 剑指offer 替换空格 * xsf * */ /*开始替换空格的函数,length为原数 ...
- 剑指offer面试题6 重建二叉树(java)
注:(1)java中树的构建 (2)构建子树时可以直接利用Arrays.copyOfRange(preorder, from, to),这个方法是左开右闭的 package com.xsf.SordF ...
随机推荐
- [译] OpenStack Kilo 版本中 Neutron 的新变化
OpenStack Kilo 版本,OpenStack 这个开源项目的第11个版本,已经于2015年4月正式发布了.现在是个合适的时间来看看这个版本中Neutron到底发生了哪些变化了,以及引入了哪些 ...
- [转]How to open specific page in the application by clicking on the notification
本文转自:https://github.com/phonegap-build/PushPlugin/issues/213 问:Hello, I would like to know how can I ...
- ARM学习篇 中断定时理解
1. 中断控制器 a. 中断处理流程 P1--摘自S3C2440A手册 P1简要阐述了S3C2440A内置中断控制器处理中断的流程: ●若某中断有自中断,则先接收子中断请求,否则,直接接受源中断. ...
- 【转】ACM搜索算法总结 --By GreenHand
搜索是ACM竞赛中的常见算法,本文的主要内容就是分析它的 特点,以及在实际问题中如何合理的选择搜索方法,提高效率.文章的第一部分首先分析了各种基本的搜索及其各自的特点.第二部分在基本搜索方法的基础上提 ...
- luogu2038[NOIP2014 T4]无线网络发射器选址
题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ...
- HTML 学习笔记(链接)
HTML链接 超链接可以是一个字,一个词,或者一组词,也可以是一幅图像,您可以点击这些内容来跳转到新的文档或者当前文档中的某个部分. 当您把鼠标指针移动到网页中的某个链接上时,箭头会变为一只小手. 我 ...
- Linux的chattr与lsattr命令
有时候你发现用root权限都不能修改某个文件,大部分原因是曾经用chattr命令锁定该文件了.chattr命令的作用很大,其中一些功能是由Linux内核版本来支持的,不过现在生产绝大部分跑的linux ...
- PAT 1005. 继续(3n+1)猜想 (25)
卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候, ...
- [转]使用 google gson 转换Timestamp或Date类型为JSON字符串.
创建类型适配类: import java.lang.reflect.Type; import java.sql.Timestamp; import java.text.DateFormat; impo ...
- 进程控制块(Process Control Block, PCB)
是为了管理进程设置的一个数据结构.是系统感知进程存在的唯一标志.通常包含如以下的信息:(1)进程标识符(唯一)(2)进程当前状态,通常同一状态的进程会被放到同一个队列:(3)进程的程序和数据地址(4) ...