INTERCAL to wspaniały język, ale nie zawsze łatwo jest zrozumieć kod innych ludzi. Jest tak szczególnie w przypadku, gdy używają instrukcji COME FROM.
Definicja wyzwania
- Napisz program lub funkcję, która pobierze kod źródłowy programu INTERCAL jako strumień tekstu / danych. Jeśli piszesz funkcję, zalecane jest także zapewnienie programu do wywołania funkcji, ale nie będzie się ona liczyła do twojego wyniku.
- Wyjściem funkcji będzie strumień tekstowy / danych skoków wykonywanych przez program, zgodnie z następującymi instrukcjami. Wynik nie musi być drukowany, ale musi to być pojedynczy tekst, a nie tablica ciągów znaków (na przykład).
Każdy wiersz wyniku będzie składał się z instrukcji, która będzie COME FROM, i numeru linii jej instrukcji COME FROM, oddzielonych znakiem
->
. Przykład:(310) DO .4 <- .3 -> 55
Możesz przyciąć te wiersze kodu źródłowego, ale nie jest to konieczne.
- Przypadki testowe będą składały się wyłącznie z niezliczonych etykiet (tj. Etykiet całkowitych).
- Dane wyjściowe muszą być posortowane według kolejności kodu źródłowego instrukcji, które będą COME FROM, a nie według ich etykiety, ani kolejności instrukcji COME FROM ani ich etykiet.
- Możliwe jest, aby wiele instrukcji pochodziło z tej samej etykiety. W takich przypadkach numery linii COME FROM muszą być posortowane i oddzielone przecinkami.
- Możliwe jest, że instrukcja przyjdzie sama.
- Instrukcja COME FROM może być poprzedzona instrukcją NOT. W takich przypadkach numer linii musi być owinięty w nawiasy kwadratowe.
- Słowa COME FROM mogą pojawić się w komentarzu i muszą zostać zignorowane. Nie musisz w pełni analizować pliku: jeśli po nich następuje etykieta (liczba w nawiasach), możesz założyć, że jest to prawdziwa instrukcja.
Punktacja
Uczestnicy będą oceniani według długości znaków ich programu lub funkcji.
Przypadki testowe
Wszystkie te przypadki testowe pochodzą z repozytorium calithmetcalf / intercal Github . Chociaż każda przydatna aplikacja bezpiecznie zaakceptuje dowolne dane wejściowe, do celów tego wyzwania potrzebujesz tylko tych pięciu przypadków testowych.
(10) PLEASE DON'T GIVE UP -> 87
(33) DON'T GIVE UP -> 92
(15) DO (13) NEXT -> 26
(16) DO .12 <- .1 -> 6
(23) DO (21) NEXT -> 3
(7202) DO RETRIEVE .203+,202 -> 75
(4202) DO ,202SUB.201.202#7 <- ,201SUB.201.202#7 -> 108
(6202) DO ,201SUB.201.202#7 <- ,202SUB.201.202#7 -> 117
(4203) DO READ OUT ,201SUB.201.202#7 -> 133
(4302) DO .302 <- .2 -> 181
(5410) DO ,400SUB#124 <- #4 $ #17 -> 293
(3410) PLEASE (4410) NEXT -> 288
(5402) DO (412) NEXT -> 328
(4412) PLEASE (3412) NEXT -> 334
(3423) DO FORGET #2 -> 375
(4404) DO RETRIEVE .311+.312 -> 411
(5404) PLEASE DO (414) NEXT -> 430
(4434) DO FORGET #1 -> 441
(3454) DO (103) NEXT -> 451
(5502) DO .512 <- .312 -> 520
(8503) PLEASE RETRIEVE .311+.312 -> 621
(7503) DO (302) NEXT -> 515
(3622) DO (302) NEXT -> 514
(603) PLEASE FORGET #2 -> 622
(10) DO NOTHING -> 5, 11
(20) PLEASE (100) NEXT -> 6
(30) PLEASE (200) NEXT -> 12
(103) DO (104) NEXT -> 27
(104) DO (105) NEXT -> 19
(1) DO (2) NEXT -> 36
(2) DO (105) NEXT -> 194
(202) DO NOT .2 <- #2 AGAIN -> [196]
(203) DO (204) NEXT -> 167
(204) DO (205) NEXT -> 159
(8201) DO NOTHING -> 165, 271
(8202) PLEASE NOTE Fork threads, one dormant, one alive -> 53, 58
(8211) DO COME FROM (8211) -> 60
(8216) DO NOTHING -> 71
(8215) DO NOTHING -> 68
(8217) DO COME FROM (8217) AGAIN -> 118
(8299) DO COME FROM (8299) AGAIN -> 141
(8274) DO (8273) NEXT ONCE -> 158
(8259) PLEASE DO NOTHING -> 166
(8276) DO COME FROM (8276) AGAIN -> 199
(8278) PLEASE DO COME FROM (8278) AGAIN -> 237
INTERCAL is a wonderful language
oddany za obraźliwy język.
^(\d+)
chwyta etykietę?