2020牛客国庆集训派对day1 F

Light Emitting Hindenburg

https://ac.nowcoder.com/acm/contest/7817/F

分析

题目要求我们求出至少 个数全部 之后的最大值。我们考虑到 。所以我们其实求出恰好 个就好了。对于第 位要为一,那么这 个数这一位也必须全部为 。如果可以在这一位找到 个数,那么,保留除了这一位为 的,然后继续考虑下一位。否则直接考虑下一位。这样的答案是不劣的,那么总的复杂度为

代码

#include<bits/stdc++.h>
using namespace std;
vector<int> A,B;
int n,k;
int main() {
    scanf("%d%d",&n,&k);
    for(int i = 1,x;i <= n;i++) scanf("%d",&x),A.push_back(x); 
    for(int i = 30;~i;i--) {
        for(auto x:A) if((x>>i)&1) B.push_back(x);
        if(B.size() >= k) swap(A,B);B.clear();
    }
    int ans = (1<<30)-1;
    for(auto x:A)ans &= x;
    cout << ans << endl;
}
比赛题解 文章被收录于专栏

近期比赛的题解应该有吧。。。

全部评论

相关推荐

点赞 评论 收藏
分享
喜欢走神的孤勇者练习时长两年半:爱华,信华,等华,黑华
点赞 评论 收藏
分享
6 收藏 评论
分享
牛客网
牛客企业服务