Potęgi, które chcą być w stanie szybko przekonwertować dowolną liczbę, którą mają, na własną bazę liczbową, przy użyciu dowolnego formatu, jaki chcą.
Wkład
Twój program musi zaakceptować 3 parametry.
- Numer: numer ciągu do konwersji
- InputFormat: ciąg podstawowy, w którym aktualnie znajduje się liczba
- OutputFormat: ciąg podstawowy, na który ma zostać przekonwertowana liczba.
Wydajność
Twój program musi przekonwertować Number
ze starej bazy numerów InputFormat
na nową bazę numerówOutputFormat
Przykłady
("1","0123456789","9876543210") = "8"
("985724","9876543210","0123456789ABCDEF") = "37C3"
("FF","0123456789ABCDEF","0123456789") = "255"
("FF","0123456789ABCDEF","01234567") = "377"
("18457184548971248772157", "0123456789","Aa0Bb1Cc2Dd3Ee4Ff5Gg6Hh7Ii8Jj9Kk,Ll.Mm[Nn]Oo@Pp#Qq}Rr{Ss-Tt+Uu=Vv_Ww!Xx%Yy*Zz") = ",sekYFg_fdXb"
Dodatkowy
Nowy test 77 podstawy nie jest wymagany, jeśli działa
- jeśli jesteś w języku, w którym musisz najpierw przekonwertować numer i jesteś zamknięty w 32Bit, możesz go pominąć.
- ponieważ jest to dodatkowy test.
Wszystkie przykłady zostały wygenerowane przez PHP 7.2 z rozszerzeniem bcmath przy użyciu następującego kodu (vars min, ale sformatowany kod). prawdopodobnie będzie krótsza droga, to jest właśnie sposób, w jaki wymyśliłem system, z którym musiałem to zrobić, fajnie byłoby sprawdzić, czy ktoś mógłby wymyślić krótszą wersję.
PHP 7.2 (bcmath - rozszerzenie) 614 bajtów
<?php
function f($a, $b, $c)
{
$d= str_split($b,1);
$e= str_split($c,1);
$f= str_split($a,1);
$g=strlen($b);
$h=strlen($c);
$k=strlen($a);
$r='';
if ($c== '0123456789')
{
$r=0;
for ($i = 1;$i <= $k; $i++)
$retval = bcadd($retval, bcmul(array_search($f[$i-1], $d),bcpow($g,$k-$i)));
return $r;
}
if ($b!= '0123456789')
$l=f($a, $b, '0123456789');
else
$l= $a;
if ($l<strlen($c))
return $e[$l];
while($l!= '0')
{
$r= $e[bcmod($l,$h)].$r;
$l= bcdiv($l,$h,0);
}
return $r;
}
Punktacja
To jest kod golfowy; najkrótszy kod wygrywa. Obowiązują standardowe luki.
["zX", "tXdsyqzSDRP02", "brFNC02bc"] => "cb"
. (lub cokolwiek to właściwie powinno być, jeśli jest to nieprawidłowe)