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

斐波那契凤尾

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 ) //首次出现
全部评论

相关推荐

01-08 09:40
中南大学 Java
苏苏加油努力:你的女神不回你消息,并且给别的男生发消息 be like
点赞 评论 收藏
分享
乐观的打工人前程似锦:怎么说呢🤔️,学历够,专业技能看起来也有那么回事,就是项目会不会差点?dji更喜欢较为复杂的工程落地的项目吧?如果有一些title的项目就更好了。有实习也是加分项,搞过神经网络应该也是加分项。进面应该可以,还是要看技术过硬
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务