C++ 滑翔翼

小T和小K都是OIER,入选省队后有幸去苏州参加JSOI集训,训练之余,他们相约一起去苏州乐园玩。
苏州乐园里有一个非常热门的游乐项目叫双人滑翔翼。小T想和小K一起乘双人滑翔翼,但是排在他们前面的一大群人却为了搭配问题而争执不休,小T和小K便自告奋勇上前为他(她)们排扰解难。
排在小T和小K前面的一大群人中有N个男人和N个女人。本着“男女搭配,干活不累”的原则,他(她)们希望一男一女结成对子飞上天去。由于双人滑翔翼飞行的稳定性很大程度上决定于两侧是否平衡,所以两个人体重相差越小则组成的搭档也越好。
现在已知每个人的体重,你的任务就是将所有人结成N对并使各对的体重差的总和最小。一对的体重差定义为重的减轻的的值,此值一定大于等于0,譬如有一对人,男的体重为50,女的体重为55,则他(她)们的体重差为5,反过来如果男的体重为55,女的体重为50,则他(她)们的体重差仍然是5。

#include
using namespace std;
int main()
{
	int n,sum = 0;
	cin >> n;
	int a[n],b[n];
	for(int i=0;i<n;i++)
		scanf("%d",&a[i]);
	for(int i=0;i<n;i++)
		scanf("%d",&b[i]);
	
	sort(a,a+n);	
	sort(b,b+n);
	for(int i=0;i<n;i++)
		sum += abs(a[i] - b[i]);
	cout << sum;	
	return 0;
}

你可能感兴趣的:(算法)