Wir definieren die Funktion g als g (n) = n XOR (n * 2) für eine beliebige ganze Zahl n> 0 .
Wenn x> 0 ist , finde die kleinste ganze Zahl y> 0, so dass g k (y) = x für einige k> 0 ist .
Beispiel
x = 549
549 = 483 XOR (483 * 2) (as binary: 1000100101 = 111100011 XOR 1111000110)
483 = 161 XOR (161 * 2) (as binary: 111100011 = 10100001 XOR 101000010)
Was bedeutet, dass g 2 (161) = 549 ist . Wir können nicht weiter gehen, da es keine n , so dass g (n) 161 = . Die erwartete Ausgabe für x = 549 ist also y = 161 .
Regeln
- Sie dürfen keine ungültigen Einträge unterstützen. Für den Eingabewert x ist garantiert ein Paar (y, k) vorhanden .
- Das ist Code-Golf , also gewinnt die kürzeste Antwort in Bytes!
Testfälle
3 --> 1
5 --> 1
6 --> 2
9 --> 7
10 --> 2
23 --> 13
85 --> 1
549 --> 161
960 --> 64
1023 --> 341
1155 --> 213
1542 --> 2
9999 --> 2819
57308 --> 19124
57311 --> 223
983055 --> 1
a(n) = g(n)