【题解】滑翔翼
【题目描述】
小T和小K都是OIER,入选省队后有幸去苏州参加JSOI集训,训练之余,他们相约一起去苏州乐园玩。
苏州乐园里有一个非常热门的游乐项目叫双人滑翔翼。小T想和小K一起乘双人滑翔翼,但是排在他们前面的一大群人却为了搭配问题而争执不休,小T和小K便自告奋勇上前为他(她)们排扰解难。
排在小T和小K前面的一大群人中有N个男人和N个女人。本着“男女搭配,干活不累”的原则,他(她)们希望一男一女结成对子飞上天去。由于双人滑翔翼飞行的稳定性很大程度上决定于两侧是否平衡,所以两个人体重相差越小则组成的搭档也越好。
现在已知每个人的体重,你的任务就是将所有人结成N对并使各对的体重差的总和最小。一对的体重差定义为重的减轻的的值,此值一定大于等于0,譬如有一对人,男的体重为50,女的体重为55,则他(她)们的体重差为5,反过来如果男的体重为55,女的体重为50,则他(她)们的体重差仍然是5。
【输入描述】
第一行包含一个自然数N(1≤N≤1000),表示有N对人;
第2~N+1行:每行包含一个自然数,表示N个男人的体重;
第N+2~2N+1行:每行包含一个自然数,表示N个女人的体重。
【输出描述】
仅有一行包含一个整数,表示配对后N对男女的体重差的总和的最小值。
【样例输入】
4 2 8 5 5 1 4 10 7
【样例输出】
6
【题目分析】
参考答案
#include<bits/stdc++.h>
using namespace std;
int a[1000001],b[1000001];
bool cmp(int a,int b) {
return a>b;
}
int main() {
int n,ans=0;;
cin>>n;
for(int i=0; i<n; i++) {
cin>>a[i];
}
for(int i=0; i<n; i++) {
cin>>b[i];
}
sort(a,a+n,cmp);
sort(b,b+n,cmp);
for(int i=0; i<n; i++) {
ans+=abs(a[i]-b[i]);
}
cout<<ans;
return 0;
}扫描二维码推送至手机访问。
版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

