您的位置:首页 > 其它

Codeforces-429-2-C Leha and Function

2017-09-13 12:10 441 查看
题意:

给出两个串,第一个串称为A,第二个串称为B,两个串的长度相等,求

的最大和, F(n, k)表示从1-n,你取出k的数字的子集, F(n, k)就等于你取出的k的数字中的最小值,而题目的要求就是让你重新给A排序,使得这个和值最大。

思路:我们每次从n个数字中取出k个数字时,最优的策略就是取n的前k个数字,这样肯定是最优的,那么给A重新排序的时候,我们可以这样想从n个数字中取出的数字越少和式肯定最大,所以此时我们只需要使得A串中的大的数对应B串中小的数,这样肯定是最大的

代码如下:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int MAXN=200050;
struct Dig
{
int x;
int idx;

} d1[MAXN],d2[MAXN];
bool cmp1(Dig d1,Dig d2)
{
return d1.x>d2.x;
}
bool cmp2(Dig d1,Dig d2)
{
return d1.x<d2.x;
}
bool cmp3(Dig d1,Dig d2)
{
return d1.idx<d2.idx;
}
int main()
{
int n;
scanf("%d",&n);
for(int i=0; i<n; i++)
{
scanf("%d",&d1[i].x);
d1[i].idx=i;
}
sort(d1,d1+n,cmp1);
for(int i=0; i<n; i++)
{
scanf("%d",&d2[i].x);
d2[i].idx=i;
}
sort(d2,d2+n,cmp2);
for(int i=0; i<n; i++)
{
d1[i].idx=d2[i].idx;
}
sort(d1,d1+n,cmp3);
for(int i=0; i<n; i++)
{
printf("%d%c",d1[i].x,i==n-1?'\n':' ');
}
printf("\n");
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息