Zainspirowany przez Taken z pytania w Stack Overflow .
Wyzwanie
Biorąc pod uwagę liczbę całkowitą n>1
, wypisz wszystkie tablice, które można uzyskać, zamieniając dokładnie dwa wpisy w tablicy [1, 2, ..., n]
.
Tablice mogą być produkowane w dowolnej kolejności.
Możesz konsekwentnie używać [0, 1, ..., n-1]
(w oparciu o 0) zamiast [1, 2, ..., n]
(w oparciu o 1).
Dodatkowe zasady
Wejścia i wyjścia są elastyczne jak zwykle .
Programy lub funkcje są dozwolone w dowolnym języku programowania . Standardowe luki są zabronione.
Najkrótszy kod w bajtach wygrywa.
Przypadki testowe
Wejście 2
daje wynik (zakładany na podstawie 1)
2 1
Dane wejściowe 3
dają dane wyjściowe (zauważ, że trzy tablice mogą być w dowolnej kolejności)
1 3 2
2 1 3
3 2 1
Wejście 4
daje wyjście
1 2 4 3
1 3 2 4
1 4 3 2
2 1 3 4
3 2 1 4
4 2 3 1
Wejście 7
daje wyjście
1 2 3 4 5 7 6
1 2 3 4 6 5 7
1 2 3 4 7 6 5
1 2 3 5 4 6 7
1 2 3 6 5 4 7
1 2 3 7 5 6 4
1 2 4 3 5 6 7
1 2 5 4 3 6 7
1 2 6 4 5 3 7
1 2 7 4 5 6 3
1 3 2 4 5 6 7
1 4 3 2 5 6 7
1 5 3 4 2 6 7
1 6 3 4 5 2 7
1 7 3 4 5 6 2
2 1 3 4 5 6 7
3 2 1 4 5 6 7
4 2 3 1 5 6 7
5 2 3 4 1 6 7
6 2 3 4 5 1 7
7 2 3 4 5 6 1
[0 ... n-1]
vs [1 ... n]
! Zawsze czuję się trochę zirytowany, gdy muszę się przyczepić z 1+
powodu indeksów zerowych J.