题解 | #求正数数组的最小不可组成和#

斐波那契凤尾

http://www.nowcoder.com/questionTerminal/c0a4b917a15f40a49ca10532ab9019fb

#include <iostream>
#include <cstdio>
using namespace std;

int main() {
    int board = -1;
    long long ans[100000];
    ans[0] = 1;
    ans[1] = 2;
    for (int i = 2; i < 100000; i++) {
        long long next = ans[i - 1] + ans[i - 2];
        if( board == -1 && next >= 1000000 ) //首次出现
        {
            board  = i+1;
        }
        ans[i] = next % 1000000;
    }
    
    int n;
    while (cin >> n) {
        long long f = ans[n - 1];
        if(n>=board)
            printf("%06d\n",f);
        else
        printf("%d\n", f);
        }
    
}
  • 思路:
  1. 利用一个数组来保存从1~100000的数
  2. 用的时候再去取就好了
  3. 时间复杂度低,空间复杂度高。属于用空间来换时间
  • 注意事项:
  1. 注意首次出现大于1000000的数,后面的数就要输出后6位了,假如不做处理,后面的数有可能低于6位。if( board == -1 && next >= 1000000 ) //首次出现
全部评论

相关推荐

10-15 10:23
门头沟学院 Java
牛可乐的头像真牛:赶紧举报,这公司绝对是诈骗的,等你签约后工作一两个月后根据合同漏洞把你开除,并且要求你赔偿3w培训费,996是为了提前筛选心甘情愿签下合同容易受骗的群体,纯粹面向校招生精心设计的骗局
你见过哪些工贼行为
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务