街區最短路徑問題
時間限制:3000 ms | 記憶體限制:65535 kb
難度:4
描述 乙個街區有很多住戶,街區的街道只能為東西、南北兩種方向。
住戶只可以沿著街道行走。
各個街道之間的間隔相等。
用(x,y)來表示住戶坐在的街區。
例如(4,20),表示使用者在東西方向第4個街道,南北方向第20個街道。
現在要建乙個郵局,使得各個住戶到郵局的距離之和最少。
求現在這個郵局應該建在那個地方使得所有住戶距離之和最小;
輸入 第一行乙個整數n<20,表示有n組測試資料,下面是n組資料;
每組第一行乙個整數m<20,表示本組有m個住戶,下面的m行每行有兩個整數0輸出
每組資料輸出到郵局最小的距離和,回車結束;
樣例輸入 23
1 12 1
1 25
2 9
5 20
11 9
1 11 20
樣例輸出 244
#include
#include
#include
int x[101],y[101];
int x2[101],y2[101];
int cmp(const void*a,const void*b)
int main()
{int n;
while(scanf("%d",&n)!=eof)
{while(n--)
{int i,n,sum=0;
scanf("%d",&n);
for(i=0;i一開始看錯題啦,相當於走方格,不能斜著走
我把所有 x 座標和 y 座標分開,這樣問題就變成了,給你 m 個數,求這些數每個減去乙個 x 的絕
對值之和的最小值,
NYOJ 7 街區最短路徑問題
描述 乙個街區有很多住戶,街區的街道只能為東西 南北兩種方向。住戶只可以沿著街道行走。各個街道之間的間隔相等。用 x,y 來表示住戶坐在的街區。例如 4,20 表示使用者在東西方向第4個街道,南北方向第20個街道。現在要建乙個郵局,使得各個住戶到郵局的距離之和最少。求現在這個郵局應該建在那個地方使得...
NYOJ 7 街區最短路徑問題
include include includeint a 30 b 30 c 110 110 c1 110 110 e 30 f 30 a陣列存的是橫座標 b陣列存的是縱座標 因為要對a和b陣列排序 所以有新增兩個陣列e和f儲存未排序時的a與b陣列 c陣列是乙個矩陣 c1陣列是來記錄該位置是否被訪問...
NYOJ 7 街區最短路徑問題
時間限制 3000 ms 記憶體限制 65535 kb 難度 4 描述 乙個街區有很多住戶,街區的街道只能為東西 南北兩種方向。住戶只可以沿著街道行走。各個街道之間的間隔相等。用 x,y 來表示住戶坐在的街區。例如 4,20 表示使用者在東西方向第4個街道,南北方向第20個街道。現在要建乙個郵局,使...