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

斐波那契凤尾

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-04 07:53
门头沟学院 C++
心愿便利贴:工作了以后回头再看待这个问题,从客观的视角来讲是因为每个人对自己的要求不同,学习好的人对自己的要求很高,所以觉得考不好就天塌了,认为自己学习好并且值得一份好工作的人也是一样,找不到符合自己预期的工作肯定也会觉得是侮辱,牛客上有很多名校大学生,肯定会存在这种好学生心态啊,“做题区”从来都不是贬义词,这是大部分普通人赖以生存的路径,这个有什么好嘲讽的,有“好学生心态”没有错,但是不要给自己太大的压力了
点赞 评论 收藏
分享
喵_coding:这实习干啥了? 没写出来一点产出啊 好好回忆一下干了啥 问问ai 问问大佬 准备些话术就好了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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