Trzy nierozróżnialne kości

12

Trzy kostki w przejrzystej kostce

Biorąc pod uwagę trzy rzuty kostkami (wartości całkowite od 1-6) w posortowanej kolejności (aby były nierozróżnialne), zamień je na sumę dwóch jasnych kości o identycznym rozkładzie.

Odpowiedzią dla trzech do jednego jest zsumowanie ich wszystkich, modulo 6. Rezultatem końcowym jest idealnie płaski rozkład, w którym każda z sześciu liczb jest jednakowo prawdopodobna (tak jak pojedyncza kostka).

Łatwo jest to zrobić dla trzech do jednego, sumując je wszystkie modulo 6. Rezultatem końcowym jest idealnie płaski rozkład, w którym każda z sześciu liczb jest jednakowo prawdopodobna (podobnie jak pojedyncza kostka). Twoim wyzwaniem jest zrobić to samo dla trzech do dwóch.

Zainspirowany łamigłówką The Three Unistinguishable Dice Puzzle . Kontynuacją „rozwiązanie” wideo została również wysłana, ale kłócą się o „elegancji” w taki czy inny sposób jest nieco subiektywna. Liczenie postaci nie jest.:D

Instrukcje

Napisz program lub funkcję, która akceptuje trzy posortowane liczby całkowite / cyfry, 1-6, i wypisuje lub zwraca jedną liczbę całkowitą, 2-12, tak że dla 216 możliwych wejść, wyjścia są rozdzielane w następujący sposób:

 222222
 333333333333
 444444444444444444
 555555555555555555555555
 666666666666666666666666666666
 777777777777777777777777777777777777
 888888888888888888888888888888
 999999999999999999999999
 AAAAAAAAAAAAAAAAAA
 BBBBBBBBBBBB
 CCCCCC

(Użyłem szesnastku, aby zachować pojedyncze znaki; wyjście dziesiętne jest w porządku)

Ponieważ kości są nierozróżnialne, nie ma dla nich żadnego wewnętrznego porządku, stąd posortowane dane wejściowe. Nie można po prostu „upuścić trzeciego”, ponieważ byłoby to niejednoznaczne.

Detale

  • Wynik to długość programu w bajtach
  • Program może być funkcją, która jest jakoś wywoływana, lub skryptem wykonawczym, który odczytuje ze standardowego wejścia, lub cokolwiek innego.
  • Brak „ponownego przewijania” przez uzyskanie entropii z innego źródła

Przykład (i test)

Zamiast przeprowadzać jakiekolwiek testy probabilistyczne, łatwo jest przejrzeć 216 (6³) przypadków wszystkich trzech kości i stwierdzić, że funkcja zwraca każdą wartość tyle razy, ile powinna. Zostanie wywołany z identycznymi parametrami (np. Przypadki 1, 2, 3i 3, 2, 1... są zakładane jako nierozróżnialne i są (arbitralnie) konwertowane 1, 2, 3).

Przykładowa odpowiedź (wyjątkowo brutalna i nieefektywna) oraz zestaw testów znajduje się poniżej w Pythonie. Mamy nadzieję, że bity testowe są wystarczająco jasne, aby przenieść się na wybrany język, choć wykonanie stdin / stdout byłoby nieco inne. Kod testowy służy tylko do testowania i nie jest oceniany (choć może być przydatny dla innych użytkowników Twojego języka lub metody I / O).

# 6x6 lists of numbers with digits sorted
LUT = [
    [[124], [133, 166], [346], [223, 355], [256], [115, 445]],
    [[233, 266], [125], [224, 455], [134], [116, 446], [356]],
    [[126], [111, 333, 555, 225], [234], [144, 366], [456], [135]],
    [[112, 244], [235], [334, 466], [145], [226, 556], [136]],
    [[146], [122, 155], [236], [113, 344], [245], [335, 566]],
    [[246], [123], [114, 336], [345], [222, 444, 666, 255], [156]],
]

def three2two(rolls):
    look_for = int('{}{}{}'.format(*sorted(rolls)))
    for i in range(6):
        for j in range(6):
            if look_for in LUT[i][j]:
                return i + j + 2

# fair distribution of the sum of two dice multiplied by 6 (because each should be hit 6x)
expected_counts = {
    2: 6,   12: 6,
    3: 12,  11: 12,
    4: 18,  10: 18,
    5: 24,   9: 24,
    6: 30,   8: 30,
    7: 36,
}

d = [1, 2, 3, 4, 5, 6]
for i in d:
    for j in d:
        for k in d:
            ijk = sorted([i, j, k])
            result = three2two(ijk)
            expected_counts[result] -= 1

for key in expected_counts:
    assert expected_counts[key] == 0
Nick T.
źródło
2
Przeczytałem pytanie kilka razy i nie mam pojęcia, o co ono prosi.
feersum
1
Oprócz tego, że to wyzwanie jest niejasne, wyzwania golfa kodowego powinny wynikać raczej z bajtów niż znaków, chyba że masz naprawdę dobry powód, aby pominąć to domyślne.
Mego
Myślę, że rozumiem. Pytanie wymaga od nas odwzorowania trzech rzutów kostkami na dwa rzuty kostkami, z pewnymi ograniczeniami.
Leaky Nun
2
Nie robisz tego za pomocą dwóch kości, używasz trzech rzutów do symulacji dwóch rzutów.
Nick T
2
Oba (a+b+c)%6+1i (a*b*c)%7zamieniają potrójną liczbę nieuporządkowanych kości w jednolity rzut pojedynczą kostką, ale niestety nie są one probabilistycznie niezależne.
xnor

Odpowiedzi:

5

Galaretka , 22 20 bajtów

6ṗ3Ṣ€ṢðQ€L€Ụịḷi’:6d6‘S

Wypróbuj online! lub symulować wszystkie 216 wyników .

tło

Każdą nieuporządkowaną trójkę rzutów kości (wymienioną z odpowiednimi wielokrotnościami) mapujemy na uporządkowaną parę rzutów kości w następujący sposób:

[1,2,3],[1,2,3],[1,2,3],[1,2,3],[1,2,3],[1,2,3] -> [1,1]
[1,2,4],[1,2,4],[1,2,4],[1,2,4],[1,2,4],[1,2,4] -> [1,2]
[1,2,5],[1,2,5],[1,2,5],[1,2,5],[1,2,5],[1,2,5] -> [1,3]
[1,2,6],[1,2,6],[1,2,6],[1,2,6],[1,2,6],[1,2,6] -> [1,4]
[1,3,4],[1,3,4],[1,3,4],[1,3,4],[1,3,4],[1,3,4] -> [1,5]
[1,3,5],[1,3,5],[1,3,5],[1,3,5],[1,3,5],[1,3,5] -> [1,6]
[1,3,6],[1,3,6],[1,3,6],[1,3,6],[1,3,6],[1,3,6] -> [2,1]
[1,4,5],[1,4,5],[1,4,5],[1,4,5],[1,4,5],[1,4,5] -> [2,2]
[1,4,6],[1,4,6],[1,4,6],[1,4,6],[1,4,6],[1,4,6] -> [2,3]
[1,5,6],[1,5,6],[1,5,6],[1,5,6],[1,5,6],[1,5,6] -> [2,4]
[2,3,4],[2,3,4],[2,3,4],[2,3,4],[2,3,4],[2,3,4] -> [2,5]
[2,3,5],[2,3,5],[2,3,5],[2,3,5],[2,3,5],[2,3,5] -> [2,6]
[2,3,6],[2,3,6],[2,3,6],[2,3,6],[2,3,6],[2,3,6] -> [3,1]
[2,4,5],[2,4,5],[2,4,5],[2,4,5],[2,4,5],[2,4,5] -> [3,2]
[2,4,6],[2,4,6],[2,4,6],[2,4,6],[2,4,6],[2,4,6] -> [3,3]
[2,5,6],[2,5,6],[2,5,6],[2,5,6],[2,5,6],[2,5,6] -> [3,4]
[3,4,5],[3,4,5],[3,4,5],[3,4,5],[3,4,5],[3,4,5] -> [3,5]
[3,4,6],[3,4,6],[3,4,6],[3,4,6],[3,4,6],[3,4,6] -> [3,6]
[3,5,6],[3,5,6],[3,5,6],[3,5,6],[3,5,6],[3,5,6] -> [4,1]
[4,5,6],[4,5,6],[4,5,6],[4,5,6],[4,5,6],[4,5,6] -> [4,2]
[1,2,2],[1,2,2],[1,2,2],[1,3,3],[1,3,3],[1,3,3] -> [4,3]
[1,4,4],[1,4,4],[1,4,4],[1,5,5],[1,5,5],[1,5,5] -> [4,4]
[1,6,6],[1,6,6],[1,6,6],[2,3,3],[2,3,3],[2,3,3] -> [4,5]
[2,4,4],[2,4,4],[2,4,4],[2,5,5],[2,5,5],[2,5,5] -> [4,6]
[2,6,6],[2,6,6],[2,6,6],[3,4,4],[3,4,4],[3,4,4] -> [5,1]
[3,5,5],[3,5,5],[3,5,5],[3,6,6],[3,6,6],[3,6,6] -> [5,2]
[4,5,5],[4,5,5],[4,5,5],[4,6,6],[4,6,6],[4,6,6] -> [5,3]
[5,6,6],[5,6,6],[5,6,6],[1,1,2],[1,1,2],[1,1,2] -> [5,4]
[1,1,3],[1,1,3],[1,1,3],[1,1,4],[1,1,4],[1,1,4] -> [5,5]
[1,1,5],[1,1,5],[1,1,5],[1,1,6],[1,1,6],[1,1,6] -> [5,6]
[2,2,3],[2,2,3],[2,2,3],[2,2,4],[2,2,4],[2,2,4] -> [6,1]
[2,2,5],[2,2,5],[2,2,5],[2,2,6],[2,2,6],[2,2,6] -> [6,2]
[3,3,4],[3,3,4],[3,3,4],[3,3,5],[3,3,5],[3,3,5] -> [6,3]
[3,3,6],[3,3,6],[3,3,6],[4,4,5],[4,4,5],[4,4,5] -> [6,4]
[4,4,6],[4,4,6],[4,4,6],[5,5,6],[5,5,6],[5,5,6] -> [6,5]
[1,1,1],[2,2,2],[3,3,3],[4,4,4],[5,5,5],[6,6,6] -> [6,6]

Dzięki temu wszystkie wyniki są możliwe do uzyskania.

Jak to działa

6ṗ3Ṣ€ṢðĠ€Ụịḷi’:6d6‘S  Main link. Argument: D (three dice rolls, sorted)

6ṗ3                     Generate lists of length 3 over [1, 2, 3, 4, 5, 6].
   Ṣ€                   Sort each triplet.
     Ṣ                  Sort the list of triplets.
      ð                 Begin a new, dyadic chain.
                        Arguments: A (list of triplets), D
       Ġ€               Group each; group the indices of each triplet by the
                        the corresponding values.
                        For a triplet [a, b, c], this yields:
                          [[1], [2], [3]] if a < b < c
                          [[1], [2, 3]]   if a < b = c
                          [[1, 2], [3]]   if a = b < c
                          [[1, 2, 3]]     if a = b = c
           Ụ            Grade up; sort the indices of A by those 2D lists.
            ịḷ          Retrieve the elements of A at those indices.
                        This sorts A as in the previous section.
              i         Find the (1-based) index of D.
               ’        Decrement to get the 0-based index.
                :6      Divide the index by 6, rounding down.
                  d6    Divmod; return quotient and remainder of division by 6.
                    ‘   Increment to map [0, ..., 5] to [1, ..., 6].
                     S  Sum the results.
Dennis
źródło
1

Pyth, 41 27 bajtów

JSSM^S6 3+2sPtj+216xo/JNJQ6

10 losowych przypadków testowych

Potwierdzenie ważności

Tabela konwersji:

2: [111, 222, 333, 444, 555, 666]
3: [112, 113, 223, 224]
4: [114, 115, 225, 226, 355, 366]
5: [116, 122, 125, 233, 244, 445, 446]
6: [126, 133, 144, 146, 255, 266, 455, 466]
7: [134, 155, 156, 166, 246, 334, 335, 556, 566]
8: [123, 135, 234, 256, 336, 344]
9: [124, 136, 235, 345]
10: [145, 236, 346]
11: [245, 356]
12: [456]

Poprzednie 41-bajtowe rozwiązanie:

Muszę zagrać w golfa ...

JSM^S6 3+2f/@co,/JNNJ.u+NY*R6t+S5_S6 6TQ0

Wypróbuj online!

Tabela konwersji:

2: [111, 222, 333, 444, 555, 666]

3: [112, 113, 114, 115]

4: [116, 122, 133, 144, 155, 166]

5: [223, 224, 225, 226, 233, 244, 255, 266]

6: [334, 335, 336, 344, 355, 366, 445, 446, 455, 466]

7: [556, 566, 123, 124, 125, 126, 134]

8: [135, 136, 145, 146, 156]

9: [234, 235, 236, 245]

10: [246, 256, 345]

11: [346,356]

12: [456]
Leaky Nun
źródło
1

CJam, 37 35 bajtów

Prawdopodobnie nie grał dobrze w golfa. Ale pokonaj Pytha.

8aq~\;[_2$>8+@7+@:U2+1$([8U4$7]])er

Wypróbuj tutaj.

jimmy23013
źródło
Proponuję zmienić ten opis.
Leaky Nun