试题C 数列求值

 

 答案:4659

 

复制代码
#include <iostream>
using namespace std;

/*
  如果直接使用递归则会超时,算不出。
  (千万不要漏掉题目中给的任何一点信息)
  提示:千位不为0,可以只算前四位,后面就不管它,所以可以考虑÷10000取余
*/

int main() {
    int a = 1, b = 1, c = 1, sum;
    int i = 3;
    while (i < 20190324) {
        sum = a + b + c;
        if (sum > 10000) {   
            sum %= 10000;
        }
        a = b;
        b = c;
        c = sum;
        i++;
    }
    cout << sum;
    return 0;
}
复制代码

 

posted @   湘summer  阅读(64)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示