Marcin and Training Camp

D. Marcin and Training Camp

参考:D. Marcin and Training Camp

思路:首先先确定最大成员的ai,因为不能够某个成员i认为自己比其他所有成员都厉害,所以必须要有一个人j来压制他。压制有两种方法:①aj跟他一样大 ②ai&aj=ai,即aj可以将ai包括。但是此时ai为最大值,所以只能是情况①

然后再确定比ai小的值,也是利用上面提到的两种方法。

但是当用到方法②的时候需要考虑一个问题ajai压制之后,谁来压制aj呢,那么此时有两种可能,一种是方法①,另外一种是最大值与该值符合方法②

代码:

// Created by CAD on 2019/9/26.
#include <bits/stdc++.h>
#define ll long long
using namespace std;

const int maxn=7005;
struct stu{
    ll a,b;
    bool operator<(const stu &x)
    {
        return a<x.a;
    }
}s[maxn];
int vis[maxn];
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    int n;
    cin>>n;
    for(int i=1;i<=n;++i) cin>>s[i].a;
    for(int i=1;i<=n;++i) cin>>s[i].b;
    sort(s+1,s+n+1);
    for(int i=2;i<=n;++i)
    if(s[i].a==s[i-1].a)
        for(int j=1;j<=i;++j)
            if((s[i].a&s[j].a)==s[j].a) vis[j]=1;
    ll ans=0;
    for(int i=1;i<=n;++i)
        if(vis[i]) ans+=s[i].b;
    cout<<ans<<endl;
    return 0;
}
posted @   caoanda  阅读(322)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
点击右上角即可分享
微信分享提示