Kredyty
To wyzwanie pochodzi od @miles .
Utwórz funkcję, która oblicza skrót CRC32 ciągu wejściowego. Dane wejściowe będą ciągiem ASCII o dowolnej długości. Wyjściem będzie skrót CRC32 tego ciągu wejściowego.
Wyjaśnienie
Algorytm CRC32 i inne CRC są zasadniczo takie same, więc tylko CRC3 zostanie tutaj pokazany.
Po pierwsze, mamy wielomian generatora, który jest w rzeczywistości 4-bitową liczbą całkowitą [n + 1] (w CRC32 byłby 33-bitowy).
W tym przykładzie wielomian generatora to 1101
.
Następnie będziesz miał ciąg do mieszania, co w tym przykładzie byłoby 00010010111100101011001101
.
00010010111100101011001101|000 (1) append three [n] "0"s
1101 (2) align with highest bit
00001000111100101011001101|000 (3) XOR (1) and (2)
1101 (4) align with highest bit
00000101111100101011001101|000 (5) XOR (3) and (4)
1101 (6) align with highest bit
00000011011100101011001101|000 (7) XOR (5) and (6)
1101 (8) align with highest bit
00000000001100101011001101|000 (9) XOR (7) and (8)
1101 (10) align with highest bit
00000000000001101011001101|000 (11) XOR (9) and (10)
1101 (12) align with highest bit
00000000000000000011001101|000 (13) XOR (11) and (12)
1101 (14) align with highest bit
00000000000000000000011101|000 (15) XOR (13) and (14)
1101 (16) align with highest bit
00000000000000000000000111|000 (17) XOR (15) and (16)
110 1 (18) align with highest bit
00000000000000000000000001|100 (19) XOR (17) and (18)
1 101 (20) align with highest bit
00000000000000000000000000|001 (21) XOR (19) and (20)
^--------REGION 1--------^ ^2^
Reszta uzyskana w (21)
, gdy region 1 wynosi zero, co oznacza 001
, że byłby wynikiem skrótu CRC3.
Okular
- Wielomian generatora to
0x104C11DB7
, lub0b100000100110000010001110110110111
, lub4374732215
. - Dane wejściowe mogą być ciągiem znaków lub listą liczb całkowitych lub dowolnym innym rozsądnym formatem.
- Dane wyjściowe mogą być ciągiem szesnastkowym lub tylko liczbą całkowitą lub innym rozsądnym formatem.
- Wbudowane obliczające wartość skrótu CRC32 są niedozwolone.
Cel
Obowiązują standardowe zasady gry w golfa kodowego .
Najkrótszy kod wygrywa.
Przypadki testowe
input output (hex)
"code-golf" 147743960 08CE64D8
"jelly" 1699969158 65537886
"" 0 00000000