2-7 士兵站队问题
问题描述
在一个划分成网格的操场上,n个士兵散乱地站在网格点上。网格点由整数坐标(x,y)表示。士兵们可以沿网格边上、下、左、右移动一步,但在同一时刻任一网格点上只能有一名士兵。按照军官的命令,士兵们要整齐地列成一个水平队列,即排列(x,y),(x+1,y),…,(x+n-1,y)。如何选择x 和y的值才能使士兵们以最少的总移动步数排成一列。 编程计算使所有士兵排成一行需要的最少移动步数。
分析:中位数原理
Y轴方向
设目标坐标为M,即n个士兵最终需要移动到的Y轴的坐标值为M
n个士兵的Y轴坐标分别为: Y0,Y1,Y2……Yn−1 Y 0 , Y 1 , Y 2 … … Y n − 1
则最优步数 S=|Y0−M|+|Y1−M|