首页 > 其他 > 详细

5.5 每日一题题解

时间:2020-05-05 13:07:28      阅读:59      评论:0      收藏:0      [点我收藏+]

博弈论

涉及知识点:

  • 构造/思维

solution:

  • \(这个题得仔细想想,肯定不能把能够造的所有数字求出来,那样的数很大,而且还不容易找\)
  • \(我们可以惊奇的发现答案不可能超过10000,因为数列生成的四位数只有O(n)个,所以从小到大枚举答案暴力判断即可。\)

std:

#include <bits/stdc++.h>
using namespace std;
#define ll long long
const int maxn = 1005;
int a[maxn];
map<int ,int > mp;
 
int main()
{
    int n;
    cin>>n;
    for(int i=1;i<=n;i++){
        scanf("%d",&a[i]);
        mp[a[i]] = 1;
    }
 
    for(int i=n-1;i>=1;i--){
        int x = a[i]*10 + a[i+1];
        mp[x] = 1;
    }
    for(int i=n-2;i>=1;i--){
        int x = a[i]*100 + a[i+1]*10 + a[i+2];
        mp[x] = 1;
    }
 
    for(int i=0;i<=999;i++){
        if(mp[i] == 0){
            cout<<i<<endl;
            return 0;
        }
    }
    return  0;
}

5.5 每日一题题解

原文:https://www.cnblogs.com/QFNU-ACM/p/12830326.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!