题目描述
给定数列 1, 1, 1, 3, 5, 9, 17, …,从第 4 项开始,每项都是前 3 项的和。求 第 20190324 项的最后 4 位数字。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一 个 4 位整数(提示:答案的千位不为 0),在提交答案时只填写这个整数,填写 多余的内容将无法得分。
思路,题目坑点
注意提示:千位不能为0!!!!!!!!!!!!
思路:这题乍一看very easy ,但如果按平常代码算出结果提交则是错误,开始思路不就是一个递推数列,加个for循环结果不就AC了吗,结果错误答案出现了:0649
代码贴上
package com.queston2019;
import java.util.ArrayList;
/*
给定数列 1, 1, 1, 3, 5, 9, 17, …,从第 4 项开始,每项都是前 3 项的和。求 第 20190324 项的最后 4 位数字。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一 个 4 位整数(**提示:答案的千位不为 0)**,在提交答案时只填写这个整数,填写 多余的内容将无法得分。
*/
public class 数列求值 {
public static void main(String[] args) {
int[] arr = new int[200000000];
arr[0]=1;
arr[1]=1;
arr[2]=1;
for (int i = 3; i <=20190324; i++) {
arr[i]=(arr[i-1]+arr[i-2]+arr[i-3])%10000;
}
System.out.println(arr[20190323]);
}
}
错误纠正
arr[i]=(arr[i-1]+arr[i-2]+arr[i-3])%10000;
本题算出最后结果后发现不和题意,调试后还是一样,故肯定与最后4位数有关(%10000)