面试题 10. 斐波那契数列 题目一:求斐波那契数列的第n项 题目描述:求斐波拉契数列的第n项 写出一个函数,输入n,求斐波拉契(Fibonacci)数列的第n项.斐波拉契数列定义如下: C++ 实现 /* 斐波拉契数列 */ #include <iostream> using namespace std; /* 递归实现 */ long long Fibonacci1( unsigned int n ) { if ( n <= 1 ) { return(n); } return(Fib…
题目:大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0).n<=39 分析:第一种方法:递归,45时,时间为5s,50时,我就等不及了.原因是重复调用问题,如下面的Fibonacci方法.第二种方法:使用一个变量记录之前的和的值,如下面的Fibonacci1方法. public class Solution10 { public int Fibonacci(int n) { if(n<=0){ return 0; } if(n==1){ ret…
题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 牛客网链接 js代码 function Find(target, array) { // write code here if (array.length < 0) return false let row = array.length let col = array[0].length let…
题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 左边的数比右边的小,下面的比上面的大,所以右上角查找,再把特殊情况排除...大了左移,小了右移... public class Solution { public boolean Find(int target, int [][] array) { if (array == nu…
在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从 上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. public class 二维数组中的查找 { /* * 最初反应是遍历一遍,但是数组从左到右和从上到下都是递增的,那么可以把二维数组的右上角 * 作为初始比较位置.比如从右上角开始,假设右上角的数为x,输入数值为y.如果y<x,那就直接往左找,如果 y>x,就向下一行. */ public stat…