生活是一种挣扎,一种拼搏,一种无怨无悔!
题目描述
斐波那契凤尾 | 时间限制:3秒 | 内存限制:32768K
NowCoder号称自己已经记住了1 - 100000之间所有的斐波那契数。为了考验他,我们随便出一个数n,让他说出第n个斐波那契数。当然,斐波那契数会很大。因此,如果第n个斐波那契数不到6位,则说出该数;否则只说出最后6位。
输入描述
输入有多组数据。
每组数据一行,包含一个整数n(1≤n≤100000)。
输出描述
对应每一组输入,输出第n个斐波那契数的最后6位。
示例
输入
1
2
3
4
100000
输出
1
2
3
5
537501
题目解析
题目要求输出斐波那契数列的第n项,最容易写的方法就是用循环求出每一项了。而它要求的是后六位,那么我们只需要存储后六位就行了。
解题思路
先求斐波那契数列在100000以内的每一项的后六位,然后需要的时候直接输出数组里的对应值即可。以下代码用通常的循环法解决。
示例代码
#include <iostream>
#include <cstdio>
int main()
{
int fib[100001];
fib[0] = 1;
fib[1] = 1;
//提前计算斐波那契数列,只保留后6位
for (int i = 2; i <= 100000; ++i)
{
fib[i] = fib[i - 1] + fib[i - 2];
fib[i] = fib[i] % 1000000; //由于是相加,所以只要后六位不影响下一个数的结果
}
//这里利用了OJ平台计时从开始读取数据的trick,这个技巧可以用在很多题目里
int n;
while (std::cin >> n)
{
if (n < 29)
{
//斐波那契数列小于6位
printf("%d\n", fib[n]);
}
else
{
printf("%06d\n", fib[n]);
}
}
return 0;
}