Codeforces 1260 E Tournament —— 思维

This way

题意:

现在有n个人打拳,序号小的打不过序号大的,并且如果你花ai元贿赂第i个人,你就能赢。你朋友参加了比赛,你可以分配每次比赛的组队以及贿赂,问你最少需要多少钱。

题解:

我一开始还想着把每个人如何匹配做出来。。但是这道题非常简单啊,如果你不贿赂要是第一,那么你只能是第n个人,如果不贿赂进二强,那么你必须是第n/2到第n个人。如果进入4强,那么必须是第n/4到第n个,这样递归下去。
那么你就能知道你朋友是第几强,如果还要往上,那么就要贿赂能够进下一场比赛中的一个即可,所以是贿赂用钱最少的那个。那么只需要每次判断是否是2的幂次,如果是,那么就是要在之后的人中至少要贿赂一个。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int N=1e6+5;
ll a[N];
multiset<ll>s;
int main()
{
    int n;
    scanf("%d",&n);
    for(int i=1;i<=n;i++)scanf("%lld",&a[i]);
    ll ans=0;
    for(int i=n;a[i]!=-1;i--){
        s.insert(a[i]);
        if(!(i&(i-1))){
            ans+=*s.begin();
            s.erase(s.begin());
        }
    }
    printf("%lld",ans);
    return 0;
}

发布了530 篇原创文章 · 获赞 31 · 访问量 5万+

猜你喜欢

转载自blog.csdn.net/tianyizhicheng/article/details/104094685