VI Olimpiada Informatyczna 1998/99
|
Zadanie: MAG
|
Autor:
|
Etap III, dzień pierwszy | 21 kwietnia 1999 |
Plik źródłowy | MAG.??? (np. PAS,C, CPP) |
Plik wykonywalny | MAG.EXE |
Plik wejściowy | MAG.IN |
Plik wyjściowy | MAG.OUT |
Podłoga magazynu jest prostokątem podzielonym na n*m kwadratowych pól. Dwa pola są sąsiednie, jeśli mają wspólny bok. Na jednym z pól stoi paczka. Każde inne pole jest albo wolne, albo zajęte przez skrzynię, której magazynier nie jest w stanie poruszyć. Magazynier musi przepchnąć paczkę z pola początkowego P na pole docelowe K. Magazynier może przemieszczać się po wolnych polach, przechodząc z pola, na którym stoi, na dowolne z wolnych pól sąsiednich. Jeśli magazynier stoi na polu sąsiadującym z polem, na którym jest paczka, to może ją przepchnąć na pole sąsiednie z przeciwnej strony paczki, jeżeli jest ono wolne.
Napisz program, który:
W pierwszym wierszu pliku wejściowego MAG.IN są zapisane dwie dodatnie liczby całkowite n i m oddzielone pojedynczym odstępem, n,m<=100. Są to rozmiary magazynu. W każdym z kolejnych n wierszy znajduje się jedno m-literowe słowo utworzone z liter S, M, P, K, w. Litera na i-tej pozycji j-tego z tych słów oznacza stan pola o współrzędnych (i,j):
Twój program powinien zapisać w pliku wyjściowym MAG.IN:
Dla pliku wejściowego MAG.IN:
10 12 SSSSSSSSSSSS SwwwwwwwSSSS SwSSSSwwSSSS SwSSSSwwSKSS SwSSSSwwSwSS SwwwwwPwwwww SSSSSSSwSwSw SSSSSSMwSwww SSSSSSSSSSSS SSSSSSSSSSSSpoprawną odpowiedzią jest plik wyjściowy MAG.OUT
7