1387:斐波那契数列 @jobdu

题目1387:斐波那契数列

时间限制:1 秒

内存限制:32 兆

特殊判题:

提交:2816

解决:827

题目描述:

大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。斐波那契数列的定义如下:

输入:

输入可能包含多个测试样例,对于每个测试案例,

输入包括一个整数n(1<=n<=70)。

输出:

对应每个测试案例,

输出第n项斐波那契数列的值。

样例输入:
3
样例输出:
2





发现9du OJ 比起LeetCode还是差多了,一个是LeetCode绝对会完美地处理好Java的时间问题,就是O(nlogn)的算法保证能通过,而O(n2)的算法保证通不过。另一个是不会出现要用long 代替 int 才能通过的情况,类似C++要用long long的情况。而且LeetCode对错误值有显示出来!这点太有帮助了!毕竟定位不同,9du OJ更加接近于ACM的标准,LeetCode就是纯粹用于找工作!


import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.util.Scanner;


public class S9 {

	public static void main(String[] args) throws FileNotFoundException {
		BufferedInputStream in = new BufferedInputStream(new FileInputStream("S9.in"));
		System.setIn(in);
		Scanner cin = new Scanner(System.in);
		
		while (cin.hasNextInt()) {
			long n = cin.nextInt();
			System.out.println(fib(n));
		}
	}
	
	public static long fib(long n){
		if(n == 0){
			return 0;
		}else if(n == 1){
			return 1;
		}else{
			long a = 0;
			long b = 1;
			long sum = 0;
			for(long i=2; i<=n; i++){
				sum = a + b;
				a = b;
				b = sum;
			}
			return sum;
		}
	}
	
	
}


你可能感兴趣的:(1387:斐波那契数列 @jobdu)