蓝桥杯:数列求值 (斐波那契 · 改) 对溢出的处理

针对蓝桥杯中的一项数列求值问题,该文探讨了如何处理由于大量递推导致的溢出问题。通过审题发现,只需求解数列第20190324项的最后4位数字。由于高位数字对最后4位没有影响,因此采用模除10000的方法,确保只计算并保留最后4位,实现了避免溢出的有效策略。
摘要由CSDN通过智能技术生成

蓝桥杯:数列求值 (斐波那契 · 改) 对溢出的处理

【问题描述】

给定数列 1, 1, 1, 3, 5, 9, 17, …,从第 4 项开始,每项都是前 3 项的和。求
第 20190324 项的最后 4 位数字。

思路

一开始我是打算直接递推求的,但是我看到项数我傻了,这用long long 也会溢出无数次的啊

于是 再 审 题

第 20190324 项的最后 4 位数字。

注意这个最后四位数字 ↑

因为会溢出,所以不可能在不使用高精度的情况下,直接求出用标准整形表达的数字,但是前面第五位以及其他高位数字,对于最后四位数字的求解,没有影响,比如

1141234 + 5145611 = 6286845 最后四位为 6845
31234 + 75611 = 106845 最后四位为 6845
1234 + 5611 = 6845 最后四位为 6845

那么把所有的运算都只取最后四位就好了,即模除10000

代码

在这里插入图片描述

#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值