2020牛客寒假算法基础集训营2 I题建通道

牛客网链接:https://ac.nowcoder.com/acm/contest/3003/I

 

 

 

 

 题解:第一眼最小生成树,然后算一波时间复杂度超时...(比赛完大佬说最小生成树可以过......)

放一下官方题解:

tai 6 le 

#include <cstdio>
#include <algorithm>
#include <cassert>
using namespace std;
const int N = 2e5 + 5;
int n, k;
int v[N], va, vo, ans;
int main() {
  scanf("%d", &n);
  for (int i = 1; i <= n; i++)
    scanf("%d", &v[i]);
  sort(v + 1, v + n + 1);
  va = 0x7fffffff;
  for (int i = 1; i <= n; i++) {
    va &= v[i];
    vo |= v[i];
  }
  v[n + 1] = 2e9;
  for (int i = n; i; i--)
    k += (v[i] != v[i + 1]);
  va ^= vo;
  for (int i = 0; i <= 30; i++) {
    int cur = 1 << i;
    if (va & cur) {
      ans = cur * (k - 1);
      break;
    }
  }
  printf("%d\n", ans);
  return 0;
}

 

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-01 11:27
点赞 评论 收藏
分享
点赞 评论 收藏
分享
程序员小白条:你是沟通了900个,不是投了900份简历,你能投900份,意味着对面都要回复你900次,你早就找到实习了,没亮点就是这样的,别局限地区,时间投的也要早,现在都要7月了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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