题目如下:
思路:
原本想着在它们最小点和最大点的中线;
但在点上少一个点还可以距离可以更小一点;
如果点的数量为偶数,则目标位置在他们中间两点之间;
如果点的数量为ji数,这目标位置在中间点上;
代码如下:
#include<bits/stdc++.h>
using namespace std;
int main()
{
long int n,a[100005],minx = 10000,manx = 0,ans = 0;
cin>>n;
for(long int i=1;i<=n;i++)
{
cin>>a[i];
}
sort(a+1,a+n+1);
if(n%2==0)
{
int sum = (a[n/2]+a[n/2 + 1])/2;
for(long int i=1;i<=n;i++)
{
ans += abs(sum - a[i]);
}
cout<<ans;
}else{
int sum = a[n/2 + 1];
for(long int i=1;i<=n;i++)
{
ans += abs(sum - a[i]);
}
cout<<ans;
}
return 0;
}