本文主要是介绍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;
}
这篇关于Codeforces 1260 E Tournament —— 思维的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!