原文链接:我的个人博客
原题链接
思路
以下思路来自柳神博客
题目大意:给定一段一段的绳子,你需要把它们串成一条绳。每次串连的时候,是把两段绳子对折,再如下图所示套接在一起。这样得到的绳子又被当成是另一段绳子,可以再次对折去跟另一段绳子串连。每次串连后,原来两段绳子的长度就会减半。给定N段绳子的长度,你需要找出它们能串成的绳子的最大长度~
分析:因为所有长度都要串在一起,每次都等于(旧的绳子长度+新的绳子长度)/2,所以越是早加入绳子长度中的段,越要对折的次数多,所以既然希望绳子长度是最长的,就必须让长的段对折次数尽可能的短。所以将所有段从小到大排序,然后从头到尾从小到大分别将每一段依次加入结绳的绳子中,最后得到的结果才会是最长的结果~
代码
#include <bits/stdc++.h>
using namespace std;
int n;
vector<int> v;
int main(){
cin>>n;
v.resize(n);
for(int i=0;i<n;i++){
cin>>v[i];
}
sort(v.begin(),v.end());//排序
double ans=v[0];
for(int i=1;i<n;i++){
ans = (ans+v[i])/2;
}
cout<<int(ans)<<endl;
return 0;
}