Znasz te drewniane zabawki z małymi łożyskami kulkowymi, w których obiekt ma poruszać się po labiryncie? To trochę tak. Biorąc pod uwagę labirynt i serię ruchów, określ, gdzie kończy się piłka.
Deska jest trzymana pionowo, a kula porusza się tylko grawitacyjnie, gdy deska jest obracana. Każdy „ruch” to obrót (w radianach).
Labirynt to po prostu koncentryczne okrągłe ściany, przy czym każda ściana ma dokładnie jeden otwór w zewnętrznym korytarzu, podobnie do tego (załóżmy, że te ściany są okręgami i nie są spiczaste):
Jak widać, piłka zaczyna się na środku i próbuje się wydostać. Piłka będzie natychmiast spadają poprzez najszybciej jak prawidłowa orientacja zostanie osiągnięty, nawet jeśli jest to w połowie obrotu. Pojedynczy obrót może spowodować, że piłka spadnie przez wiele otworów. Na przykład obrót >= n * 2 * pi
wystarczy, aby uciec od labiryntu.
Na potrzeby gry piłka znajdująca się w 0.001
radianach otworu jest uważana za „dopasowaną” i spada do następnego korytarza.
Wejście:
Dane wejściowe składają się z dwóch części:
Labirynt podaje liczba całkowita
n
reprezentująca liczbę ścian / otworów w labiryncie. Po nim następująn
wiersze, po jednym na każdej z nich, wskazujące miejsce przejścia do następnego korytarza.Ruchy są podawane jako liczba całkowita
m
reprezentująca liczbę wykonanych ruchów, a następnie (ponownie w osobnych liniach)m
obroty planszy w radianach zgodnie z ruchem wskazówek zegara (ujemna jest przeciwna do ruchu wskazówek zegara).
Wszystkie pozycje przejścia podano jako 0 rad = up
, z dodatnimi radianami idącymi zgodnie z ruchem wskazówek zegara.
Dla powyższego przykładowego obrazu dane wejściowe mogą wyglądać następująco:
7 // 7 openings
0
0.785398163
3.14159265
1.74532925
4.71238898
4.01425728
0
3 // 3 moves
-3.92699082
3.14159265
0.81245687
Wyjście:
wypisz numer korytarza, w którym kończy się kula. Korytarze mają indeks zerowy, zaczynając od środka, więc zaczynasz 0
. Jeśli przejdziesz przez jeden otwór, znajdziesz się na korytarzu 1
. Jeśli uciekniesz z całego labiryntu, wypisz dowolną liczbę całkowitą>= n
Dla próbki wejściowej są trzy ruchy. Pierwszy spowoduje, że piłka spadnie przez dwa otwory. Drugi nie znajdzie otwór, a trzeci stwierdzi jedną . Kula jest teraz w korytarzu 3
, więc oczekiwany wynik to:
3
Zachowanie jest niezdefiniowane dla niepoprawnych danych wejściowych. Prawidłowe dane wejściowe są dobrze sformułowane, z n >= 1
i m >= 0
.
Punktacja to standardowy kod golfowy, najmniejsza liczba bajtów wygrywa. Standardowe luki są zabronione. Dane wejściowe nie mogą być zakodowane na stałe, ale można je pobierać ze standardowych danych wejściowych, argumentów, konsoli itp. Dane wyjściowe mogą być przesyłane do konsoli, pliku itp., Po prostu sprawiają, że dane wyjściowe są widoczne.
1
, będziesz po prostu pracował z dużymi dziurami, nie skacząc kulkami do środka otworu, gdy spadną.Odpowiedzi:
Perl,
211191Z nowymi liniami i wcięciem dla czytelności:
Liczba ruchów na wejściu jest odrzucana, eof stdin wskazuje koniec ruchów.
źródło
JavaScript 200
EDYCJA : Oto animowany przykład udowadniający, że ten solver działa: http://jsfiddle.net/F74AP/4/
Funkcja musi zostać wywołana przez przekazanie ciągu wejściowego.
Oto wywołanie przykładu podanego przez OP:
Zwraca
3
zgodnie z przeznaczeniem.źródło