【题解】数列求值
【问题描述】
给定数列 1, 1, 1, 3, 5, 9, 17, …,从第 4 项开始,每项都是前 3 项的和。求 第 20190324 项的最后 4 位数字。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一 个 4 位整数(提示:答案的千位不为 0),在提交答案时只填写这个整数,填写 多余的内容将无法得分。
解题思路:
这道题有两种方法,递推和递归,但是递归20190324数字太大,会出现栈溢出,所以只能用递推来做。
用求模运算 防止溢出。
【代码】
import java.util.Scanner;
/**
* 题目:数列求值
* 注意: 用求模运算 防止溢出
*/
public class arr_value {
public static void main(String[] args) {
System.out.print("请输入要取第几项:");
Scanner sc = new Scanner(System.in);
int input = sc.nextInt();
int a = 1, b = 1, c = 1, temp;
// %10000 防止数太大而溢出
for (int i = 3; i < input; i++) {
temp = (a + b + c) % 10000; // 新求得的数
//注意赋值顺序
a = b % 10000;
b = c % 10000;
c = temp % 10000;
}
System.out.printf("第%d项的最后4位数字是:%d", input, c);
}
}
结果
4659
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?