Karel is a robot who lives in a rectangular coordinate
system where each place is designated by a set of integer
coordinates ( and
). Your job is to
design a program that will help Karel pick up a number of
beepers that are placed in her world. To do so you must direct
Karel to the position where each beeper is located. Your job is
to write a computer program that finds the length of the
shortest path that will get Karel from her starting position,
to each of the beepers, and return back again to the starting
position.
Karel can only move along the and axis, never diagonally. Moving
from one position
to an adjacent position , , , or has a cost of one.
You can assume that Karel’s world is never larger than
squares and
that there will never be more than beepers to pick up. Each
coordinate will be given as a pair where each value will be in
the range through the
size of that particular direction of the coordinate system.
Input
First there will be a line containing the number of
scenarios you are asked to help Karel in (at most ). For each scenario there will
first be a line containing the size of the world. This will be
given as two integers (-size and -size). Next there will be one line
containing two numbers giving the starting position of Karel.
On the next line there will be one number giving the number of
beepers. For each beeper there will be a line containing two
numbers giving the coordinates of each beeper.
Output
The output will be one line per scenario, giving the minimum
distance that Karel has to move to get from her starting
position to each of the beepers and back again to the starting
position.
Sample Input 1 |
Sample Output 1 |
1
10 10
1 1
4
2 3
5 5
9 4
6 5
|
24
|