问题描述:
在一个按照东西和南北方向划分成规整街区的城市里,n 个居民点散乱地分布在不同的街区中。用x 坐标表示东西向,用y 坐标表示南北向。各居民点的位置可以由坐标(x,y) 表示。街区中任意2 点(x1,y1) 和(x2,y2) 之间的距离可以用数值|x1-x2|+|y1-y2| 度量。
居民们希望在城市中选择建立邮局的最佳位置,使n 个居民点到邮局的距离总和最小。
编程任务:
给定n 个居民点的位置,编程计算n 个居民点到邮局的距离总和的最小值。
数据输入:
由文件input.txt 提供输入数据。文件的第1 行是居民点数n,1<=n<=10000。接下来n 行是居民点的位置,每行2 个整数x 和y,-10000<=x,y<=10000。
结果输出:
程序运行结束时,将计算结果输出到文件output.txt 中。文件的第1 行中的数是n 个居民点到邮局的距离总和的最小值。
输入文件示例 输出文件示例
input.txt output.txt
5 10
1 2
2 2
1 3
3 -2
3 3
itc上没有文件的读取读入,数据自行输入。
#include<bits/stdc++.h>
#define N 1000
using namespace std;
int dx[N],dy[N];
int main()
{
int n;
cin>>n;
int x=100000,y=100000;
int xx=0,yy=0;
for(int i=0;i<n;i++)
{
cin>>dx[i]>>dy[i];
}
for(int i=-10000;i<=10000;i++)
{
xx=0;
yy=0;
for(int j=0;j<n;j++)
{
xx+=abs(i-dx[j]);
yy+=abs(i-dy[j]);
}
x=min(x,xx);
y=min(y,yy);
}
cout<<x+y;
}