Kalkulator numerologii

19

Celem tego wyzwania jest obliczenie jednego rodzaju cyfry numerologicznej z ciągów znaków i cyfr.

  • Dane wejściowe mogą odbywać się dowolną dogodną metodą (standardowe wejście, argumenty, oddzielny plik).
  • Wejście może zawierać żadnych znaków ASCII druku, ale tylko alfanumeryczne ( A-Z, a-z, i 0-9) muszą być brane pod uwagę.
  • Wynik musi być cyfrą między gwiazdą 1i 9lub gwiazdką, *jeśli nie znaleziono żadnej litery i cyfry ... (lub nawet 0jeśli dane wejściowe zawierają dowolną liczbę 0 i nic więcej, ale to nie ma znaczenia).
  • Wartości literowe są mapowane w następujący sposób:

    1  2  3  4  5  6  7  8  9
    a  b  c  d  e  f  g  h  i
    j  k  l  m  n  o  p  q  r
    s  t  u  v  w  x  y  z
    
  • Cyfry numerologia jest obliczana przez dodanie każdej wartości ciągu, a następnie powtórzyć, dopóki nie jest tylko jedna cyfra. Próbkę do 13579, Hello, world!, 00 0 00, !@#$%^&*();, i 3.141592:

    13579 => 1 + 3 + 5 + 7 + 9 = 25 => 2 + 5 = 7
    Hello, world! => 8 + 5 + 3 + 3 + 6 + 5 + 6 + 9 + 3 + 4 = 52 => 5 + 2 = 7
    00 0 00 => 0 + 0 + 0 + 0 + 0 = 0
    !@#$%^&*(); => *
      => *
    3.141592 => 3 + 1 + 4 + 1 + 5 + 9 + 2 = 25 => 2 + 5 = 7
    3.1415926535897932384 => 
     3 + 1 + 4 + 1 + 5 + 9 + 2 + 6 + 5 + 3 + 5 + 8 + 9 + 7 + 9 + 3 + 2 + 3 + 8 + 4
     = 97 => 9 + 7 = 16 => 1 + 6 = 7
    

    (To świetnie, większość tych próbek daje 7! Ale to tylko próbka;)

    Jeszcze kilka testów:

    Bob  => 2 + 6 + 2 = 10 => 1 + 0 = 1
    Charlie => 3 + 8 + 1 + 9 + 3 + 9 + 5 = 38 => 3 + 8 = 11 => 1 + 1 = 2
    Anna => 1 + 5 + 5 + 1 = 12 => 1 + 2 = 3
    Fana => 6 + 1 + 5 + 1 = 13 => 1 + 3 = 4
    Gregory => 7 + 9 + 5 + 7 + 6 + 9 + 7 = 50 => 5 + 0 = 5
    Denis => 4 + 5 + 5 + 9 + 1 = 24 => 2 + 4 = 6
    Erik => 5 + 9 + 9 + 2 = 25 => 2 + 5 = 7
    Helen => 8 + 5 + 3 + 5 + 5 = 26 => 2 + 6 = 8
    Izis => 9 + 8 + 9 + 1 = 27 => 2 + 7 = 9
    

To jest , więc wygrywa najkrótsza odpowiedź w bajtach.

Najkrótszy według języka

F. Hauri
źródło
0 zniknie po dodaniu do czegokolwiek innego
F. Hauri
0 nie ma znaczenia! Odpowiedni wynik to pomiędzy 1i 9!
F. Hauri,
Czy możesz dodać kilka przykładów bez znaków alfanumerycznych?
ETHprodukcje
1
Mam na myśli coś takiego !@#$%^&*(); coś, co powinno wrócić *.
ETHprodukcje
Bardzo trudno było się temu oprzeć, powołując się na to w niektórych dyskusjach analiz technicznych na temat obszaru pieniędzy ... ;-p
keshlam

Odpowiedzi:

6

Matlab, 121 bajtów

s=[input('','s'),'*'];while nnz(s)>1;s=num2str(sum(mod([s(48<s&s<58)-4,s(96<s&s<123)+2,s(64<s&s<91)-2],9)+1));end;disp(s)

Matlab po prostu nie jest stworzony dla ciągów = (

wada
źródło
3
Hej, przynajmniej nie jest tak gadatliwy jak Mma: P
LegionMammal978
moje +1, nie mogłem nic lepszego. btw, czy konieczne jest złożenie dispoświadczenia?
brainkz,
@brainkz Może, ale zwykle sugeruję, aby być po bezpiecznej stronie
flawr
3

Mathematica, 174 168 163 bajtów

Catch[#-9Floor[Max[#-1,1]/9]&@If[(a=Tr[Characters@#/.{(b=a_String)?DigitQ:>FromDigits@a,b?LetterQ:>LetterNumber@a~Mod~9,b->0}])<1&&#~StringFreeQ~"0",Throw@"*",a]]&

Wykonuje pierwszy krok, a następnie oblicza cyfrowy root.

LegionMammal978
źródło
3

Ruby, 97 74 znaków

n=->s{(t=eval s.tr('a-z9A-Z','1-9'*6).scan(/\d/)*?+)&&t>9?n[t.to_s]:t||?*}

Przykładowy przebieg:

2.1.5 :001 > n=->s{(t=eval s.tr('a-z9A-Z','1-9'*6).scan(/\d/)*?+)&&t>9?n[t.to_s]:t||?*}
 => #<Proc:0x00000001b4b3f0@(irb):4 (lambda)> 

2.1.5 :002 > puts ['13579', 'Hello, world!', '00 0 00', '!@#$%^&*();', ' ', '3.141592', '3.1415926535897932384', 'Bob', 'Charlie', 'Anna', 'Izis'].map{|s|'%s : %s'%[n[s],s]}
7 : 13579
7 : Hello, world!
0 : 00 0 00
* : !@#$%^&*();
* :  
7 : 3.141592
7 : 3.1415926535897932384
1 : Bob
2 : Charlie
3 : Anna
9 : Izis
człowiek w pracy
źródło
3

Perl, 91 89 76 74 bajtów

73 + 1 dla -pprzełącznika

s/[a-z]/(ord($&)%32-1)%9+1/eig;$t="*",s/\d/$t+=$&/eg,$_=$t until/^[*\d]$/

Testy

for test in '13579' 'Hello, world!' '00 0 00' '!@#$%^&*();' ' ' \
    '3.141592' '3.1415926535897932384' \
    Bob Charlie Anna Fana Gregory Denis Erik Helen Izis ;do  
    perl -pe '
      s/[a-z]/(ord($&)%32-1)%9+1/eig;$t="*",s/\d/$t+=$&/eg,$_=$t until/^[*\d]$/
      ' < <(echo -n "$test")
    echo "  $test"
done
7  13579
7  Hello, world!
0  00 0 00
*  !@#$%^&*();
*   
7  3.141592
7  3.1415926535897932384
1  Bob
2  Charlie
3  Anna
4  Fana
5  Gregory
6  Denis
7  Erik
8  Helen
9  Izis

Dzięki @manatwork za pomoc w uratowaniu 2 14 16 15 17 znaków !!

... Myślałem o: N % 32 + Ymoże zastąpić( N & 31 ) + Y !

F. Hauri
źródło
1
Jeśli przechwycisz cały dopasowany podciąg, $1jest równy $&. Więc lepiej usuń przechwytywanie i zmień nazwę zmiennej.
manatwork
1
whileblok może być $t="*";s/\d/$t+=$&/eg;$_=$t.
manatwork,
1
Przykro nam, ale w rzeczywistości jest o 1 znak dłuższy, ponieważ należy uwzględnić -pprzełącznik w liczeniu.
manatwork,
1
Przepraszam ponownie (tym razem większe przepraszanie), ale nie udaje się to przy wprowadzaniu pojedynczych znaków innych niż słowa, na przykład „!” Powoduje to samo ”!”. ( Wygląda na to, że działa tutaj, ponieważ tutaj ciąg wejściowy jest zawsze przekazywany z końcowym znakiem nowej linii, więc w twoich przypadkach testowych nigdy nie przechodzi dane wejściowe z jednym znakiem. Użyj, echo -n "$test" | perl -pe '…'aby zobaczyć, co mam na myśli.) Możesz to rozwiązać, zmieniając whilewarunek na !/^[\d*]$/. Chociaż nie, aby zmniejszyć straty gola, można wymienić cały whilez tym: $t="*",s/\d/$t+=$&/eg,$_=$t until/^[\d*]$/.
manatwork
1
Jest jeszcze jedna poprawka, którą możesz zrobić. Ponieważ &ma niższy priorytet niż +, podczas gdy %ma wyższy, zmień &31%32i możesz usunąć nawiasy wokół tego podwyrażenia.
manatwork
3

ES6, 98 bajtów

s=>(m=s.match(/[1-9a-z]/gi))?(t=8,m.map(c=>t+=c>'@'?c.charCodeAt()&31:+c),t%9+1):/0/.test(s)?0:'*'

Nie golfowany:

function(s) {
    var m = s.match(/[1-9a-z]/gi);
    if (m) {
        var t = 0;
        for (var i = 0; i < m.length; i++) {
            if (m[i] > '@')
                t += m[i].charCodeAt(0) & 31;
            else
                t += parseInt(m[i]);
        }
        return t % 9 || 9;
    }
    return /0/.test(s) ? 0 : "*";
}

Wersja 94-bajtowa, która działa tylko na krótkich ciągach:

s=>(m=s.match(/[1-9a-z]/gi))?m.map(c=>c>'@'?c.charCodeAt()&31:c).join``%9||9:/0/.test(s)?0:'*'

Korzystanie match, mapa joinokazało się być krótsza niż przy użyciu replacedwukrotnie:

s=>(m=s.replace(/[^1-9a-z]/gi,''))?m.replace(/[a-z]/gi,c=>c.charCodeAt()&31)%9||9:/0/.test(s)?0:'*'

Przetestuj tutaj: https://jsbin.com/zizosayisi/edit?js,console

Neil
źródło
To nie działa na wejście00 0 00
rink.attendant. 6
@ rink.attendant.6 Ach, REPL używałem tylko wydruki ["0"]jak 0więc nie mogłem odróżnić.
Neil,
Znacznie lepsza niż wersja @ rink.attendant.6! Zastosowano sprytne hacki golfowe. Czy mógłby Pan wyjaśnić > '@', & 31i || 9?
Pavlo,
1
@Pavlo > '@'po prostu rozróżnia litery i cyfry. & 31jest użytecznym sposobem ignorowania różnicy między wielkimi i małymi kodami znaków, ponieważ umożliwia także bezpośrednie mapowanie kodów znaków na wartości 1..26. || 9jest używana, ponieważ % 9zwraca 0 dla wielokrotności 9, ale wielokrotne dodawanie cyfr zwraca 9 dla niezerowych wielokrotności 9. W kodzie golfowym używam (t + 8) % 9 + 1zamiast tego, co dochodzi do tego samego.
Neil,
Język jest powszechnie nazywany „JavaScript (ES6)”
edc65
2

Gema, 161 znaków

*=@n{*}
n:\A=@set{t;};<L1>=@set{t;@add{$t;@add{@mod{@sub{@mod{@char-int{$0};32};1};9};1}}};<D1>=@set{t;@add{$t;$0}};?=;\Z=@cmps{$t;;;\*;@cmpn{$t;9;$t;$t;@n{$t}}}

(Napisane tylko w celu sprawdzenia, czy działają rekurencyjne wywołania domeny).

Przykładowy przebieg:

bash-4.3$ for input in '13579' 'Hello, world!' '00 0 00' '!@#$%^&*();' ' ' '3.141592' '3.1415926535897932384'; do
>     echo -n "'$input' : "
>     gema '*=@n{*};n:\A=@set{t;};<L1>=@set{t;@add{$t;@add{@mod{@sub{@mod{@char-int{$0};32};1};9};1}}};<D1>=@set{t;@add{$t;$0}};?=;\Z=@cmps{$t;;;\*;@cmpn{$t;9;$t;$t;@n{$t}}}' <<< "$input"
>     echo
> done
'13579' : 7
'Hello, world!' : 7
'00 0 00' : 0
'!@#$%^&*();' : *
' ' : *
'3.141592' : 7
'3.1415926535897932384' : 7
człowiek w pracy
źródło
1

JavaScript (ES6), 162 159 157 bajtów

f=_=>{for(_=_.replace(/\W+/g,''),g=$=>''+[...$.toUpperCase()].reduce((p,a)=>isNaN(a)?p+(a.charCodeAt()-64)%9:+a+p,0);1<(l=_.length);_=g(_));return!l?'*':g(_)}

Wciąż próbuję znaleźć sposób na użycie niejawnego zwrotu w funkcji zewnętrznej.

Niegolfowany + nieupoważniony

f = str => {
  str = str.replace(/\W+/g, '');
  recursiveFunc = $ => String([...$.toUpperCase()].reduce(
    (prev, val) => isNaN(val) ? prev + (val.charCodeAt() - 64) % 9 : Number(val) + prev,
    0
  ));
  while (1 < (len = str.length)) {
    str = recursiveFunc(str);
  }
  return len === 0 ? '*' : recursiveFunc(str)
}
  1. Usuwa wszystkie znaki niealfanumeryczne
  2. Wywołuje funkcję rekurencyjnie w celu zredukowania znaków do ich odpowiednich wartości, gdy łańcuch jest dłuższy niż 1 znak.
    1. Konwertuje ciąg na wielkie litery, aby łatwo pracować z kodami ASCII
    2. Konwertuj na tablicę za pomocą operatora rozprzestrzeniania i uruchom akumulator
    3. Użyj isNaNfunkcji globalnej (która przekazuje dane wejściowe), aby sprawdzić, czy nie jest to liczba
      • Jeśli nie, przekonwertuj na kod ASCII i mod 9, aby uzyskać odpowiednią wartość
      • Jeśli jest to liczba, rzuć ją
  3. Jeśli długość wynosi 0, znaki alfanumeryczne nie były obecne (zwraca gwiazdkę), w przeciwnym razie zwraca wynik funkcji rekurencyjnej.
lodowisko. dozorca 6
źródło
Ta reguła łamania 00 0 00, wyjście *zamiast 0!
F. Hauri,
@ F.Hauri Naprawiono.
rink.attendant. 6
Możesz uniknąć jawnego zwrotu za pomocą operatora comman: _=>{expr;return expr}=>_=>(expr,expr)
Pavlo
@Pavlo Jak zastosować to w moim przypadku?
rink.attendant. 6
Nie działa dla mnie, wyrzuca błąd składni
Pavlo
1

Haskell, 126 bajtów

l x=[n|(c,n)<-zip(['0'..'9']++['a'..'z']++'\0':['A'..'Z'])$0:cycle[1..9],c==x]
g[]="*"
g[x]=show x
g x=f$show$sum x
f=g.(l=<<)

Zastosowanie: f "Hello, world!"-> "7".

lto tablica przeglądowa znaków do listy liczb całkowitych (lista singletonów, jeśli znaleziono char, w przeciwnym razie pusta lista). fsprawdza każdy znak swojego argumentu i spłaszcza zwróconą listę list do prostej listy liczb całkowitych i wywołań, gaby sprawdzić warunek końcowy (pusta lista (-> *) lub pojedyncza liczba całkowita) lub zadzwonić fz sumą listy dla kolejnej rundy.

nimi
źródło
1

MATL , 64 bajty

jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']

Używa bieżącej wersji (4.0.0) języka.

Mam wrażenie, że można go skrócić ...

Przypadki testowe

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> 13579
7

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> Hello, world!
7

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> 00 0 00
0

>> matl 
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> !@#$%^&*();
*

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> 3.141592
7

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> 3.1415926535897932384
7

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> Bob
1

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> Charlie
2

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> Anna
3

>> matl
 > jk42ht`YUt'[a-z]'XXY}3+w'[1-9]'XXY}6+h,9X\st9>]w2Y24Y2h!=~?x'*']
 > 
> Izis
9
Luis Mendo
źródło
Niestety nie mogłem przetestować twojej próbki. Prześlij całe przypadki testowe, w tym ostatnio dodane testy (przepraszam).
F. Hauri,
@ F.Hauri Tak, potrzebujesz Matlaba, aby je przetestować. Przepraszamy za to, nie ma jeszcze kompilatora online. Dodałem przypadki testowe
Luis Mendo,
1

Poważnie, 50 bajtów

,$ù;ú1╤▀+;#pX╗@-@-;Y`'*.`╬X1WX`╜í;s9*@%u`MΣ$;lDWX

Hex Dump:

2c24973ba331d1df2b3b237058bb402d402d3b5960272a2e7f
60ce5831575860bda13b73392a402575604de4243b6c445758

Wypróbuj online

Wyjaśniono:

,$ù                                               Read input, make it a string, lowercase
    ú                                             Push lowercase alphabet
     1╤▀+                                         Prepend base 10 digits.
         ;#pX╗                                    Remove "0" from a copy and stash in reg0
   ;          @-                                  Remove alphanumerics from input copy
                @-                                Remove nonalphanumerics from input
                  ;Y                              Push 1 if string is empty, else 0
                    `'*.`╬                        If top is truthy, output * and halt
                          X                       Discard boolean
                           1                      Push 1 to enter loop
                            WX                 WX Loop while top of stack is truthy
                              `         `M        Map this function over the string
                               ╜                  Push alphanumeric string from reg0
                                í                 Push index of this char in it
                                 ;s9*             Push 9 if found, else -9
                                     @%u          Take index mod previous: this yields the
                                                  correct conversion from the numerology
                                          Σ       Sum the resulting digits.
                                           $      Convert the sum to a string.
                                            ;lD   push 1 less than its length
kwintopia
źródło
@ F.Hauri Kliknij „Wypróbuj online”. wprowadź przypadki testowe w polu wejściowym.
kwintopia
1

Pyth, 39 bajtów

IK@J+jkUTGrz0WtK=K`smh%xtJd9-K\0)K).?\*

Wypróbuj online

Po prostu to robię, bo nie mogę spać. Może wyjaśnię to jutro ...

kwintopia
źródło
1

Pure Bash, 199 194 bajtów

eval a+={a..z};r="$1";while [ "${r:1}" ];do o=;for ((i=0;i<${#r};i++));do
l=${r:i:1};case $l in [a-zA-Z])d=${a%${l,}*};((o+=$((${#d}%9+1))));;[0-9])
((o+=l));;esac;done;r="$o";done;echo "${o:-*}"

(podział drugiej linii służy jedynie uniknięciu paska przewijania)

Reguła testu:

numerology() {
    eval a+={a..z};
    r="$1";
    while [ "${r:1}" ]; do
        o=;
        for ((i=0; i<${#r}; i++))
        do
            l=${r:i:1};
            case $l in 
                [a-zA-Z])
                    d=${a%${l,}*};
                    ((o+=$((${#d}%9+1))))
                ;;
                [0-9])
                    ((o+=l))
                ;;
            esac;
        done;
        r="$o";
    done;
    echo "${o:-*}"
}

for test in '13579' 'Hello, world!' '00 0 00' '!@#$%^&*();' ' ' \
            '3.141592' '3.1415926535897932384'\
            Bob Charlie Anna Fana Gregory Denis Erik Helen Izis ;do
    echo "$(numerology "$test")" $test
done
7 13579
7 Hello, world!
0 00 0 00
* !@#$%^&*();
*
7 3.141592
7 3.1415926535897932384
1 Bob
2 Charlie
3 Anna
4 Fana
5 Gregory
6 Denis
7 Erik
8 Helen
9 Izis
F. Hauri
źródło
1

JavaScript (ES6), 78 83

Rozwiązanie rekurencyjne. Jako rekurencja ogona zmienne t i r nie muszą być lokalne.

f=x=>(t=r=0,x.replace(/\w/g,d=>t+=1+~-parseInt(d,r=36)%9),t>9?f(''+t):r?t:'*')

Wyjaśniono

f=x=>(
  t = 0, // set initial value of counter to 0 
  r = 0, // flag to verify that we found at last one alphanumeric chars
  x.replace(/\w/g, d => ( // execute the following for each alphanumeric character
    // t += 1 + ~-parseInt(d,r=36) % 9 explained below
    r = 36, // set flag, could be any nonzero value
    d = parseInt(d,36), // convert to numeric. a..z -> 10..25, case insensitive.
    d = 1 + (d-1) % 9, // this is the arithmetic conversion required (
                       // works also with 0 because the strange implementation of % in javascript for negative numbers
    t = t + d // add to global counter
  ) ), 
  t > 9 // if t > 9 then we found some alphanumeric char, but we must repeat the loop on t
    ? f(''+t) // recursive call, t is numeric and must become a string
    : r // check flag r 
      ? t // if alphanumeric found, return t 
      : '*' // else return '*'
)

Testowy fragment kodu

f=x=>(t=r=0,x.replace(/\w/g,d=>t+=1+~-parseInt(d,r=36)%9),t>9?f(''+t):r?t:'*')

console.log=x=>O.textContent+=x+'\n';

;[['13579',7],['Hello, world!',7],['00 0 00',0],['!@#$%^&*();','*'],
['3.141592',7],['3.1415926535897932384',7],
['Bob', 1],['Charlie', 2],['Anna', 3],['Fana', 4],['Gregory', 5],
['Denis', 6],['Erik', 7],['Helen', 8],['Izis', 9]]
.forEach(t=>{
  i=t[0]+''
  k=t[1]
  r=f(i)
  console.log(i+' -> ' + r + (k==r? ' OK':' Fail - expected '+k))
  })
<pre id=O></pre>

edc65
źródło
0

Python, 154 bajty

def A(S):
 D=lambda x:int(x)if x.isdigit()else (ord(x.lower())-6)%9
 while len(S)>1:S=str(sum([D(c)for c in S if c.isalnum()]))
 print S if int(S)else"*"
Kieran Hunt
źródło
Ten test negatywny z 00 0 00!
F. Hauri,
0

Mathematica, 133 bajty

f[s_]:= ToCharacterCode@ToUpperCase@s-64/.{a_/;17>-a>6:>a+16,b_/;b<1||b>26:>""}//If[Or@@NumberQ/@#,Tr@#/.""->0//.a_:>Tr@IntegerDigits@a,"*"]&

Trochę różni się od powyższego LegionMammal978. Moja funkcja przekształca wszystko w kod znakowy, a następnie odfiltrowuje rzeczy niealfanumeryczne (zastępując je pustymi ciągami znaków). Jeśli nie ma znaków alfanumerycznych, zwraca *, w przeciwnym razie bierze cyfrowy katalog główny. To może być znacznie (~ 15B) krótsze, gdybym nie musiał zajmować się przypadkiem ciągów zerowych. C'est la vie.

Magia matematyczna dla niewtajemniczonych: foo//.a_:>Tr@IntegerDigits@ajest powtarzanym zamiennikiem: zastępuje dowolne liczby aw foo sumą ich cyfr, a następnie zamienia się ponownie, aż osiągnie ustalony punkt, tj. aPrzestaje się zmieniać w trakcie zastępowania.

Testy:

f /@ {"13579", "Hello,world!", "00 0 00", "!@#$%^&*()", "3.141592","3.1415926535897932384"}
     => {7, 7, 0, "*", 7, 7}
f /@ {"Bob", "Charlie", "Anna", "Fana", "Gregory", "Denis", "Erik",  "Helen", "Izis"}
     => {1, 2, 3, 4, 5, 6, 7, 8, 9}
hYPotenuser
źródło
Niestety nie mogłem przetestować twojej próbki. Proszę zamieścić przypadki testowe
F. Hauri
Jestem w drodze. Podczas zestawiania testów znalazłem też kilka literówek do naprawienia. Dzięki;)
hYPotenuser