Elektroniczny Skarbonka

11

Skarbonka jest pojemnik używany do zbierania monet w na to wyzwanie korzystać z czterech amerykańskich monet. Kwartał, bilon, nikiel, i Penny .

Wyzwanie

Twoim wyzwaniem jest stworzenie elektronicznej skarbonki. Napisz program (lub funkcję), który po uruchomieniu (lub wywołaniu) wyświetli (lub zwróci) liczbę posiadanych monet, a także całkowitą kwotę, jaką mają te monety.

Wejście

Sznurek, tablica itp. (Do wyboru) monet do skarbonki (bez rozróżniania wielkości liter).

 Q - Quarter(Value of 25)
 D - Dime(Value of 10)
 N - Nickel(Value of 5)
 P - Penny(Value of 1)

Wynik

Liczba monet z wkładu i całkowita kwota, oddzielone wybranym przez Ciebie separatorem różnym. (Kolejność, w jakiej wyprowadzane są sumy monet, nie ma znaczenia, ale całkowita wartość monety (suma) musi być ostatnim elementem)

Przykłady

 Input          ->       Output

 P              ->       1,0,0,0,1 or 0,0,0,1,1 or 0,0,1,0,1 or 1,1
 N              ->       0,1,0,0,5
 D              ->       0,0,1,0,10 
 Q              ->       0,0,0,1,25
 QQQQ           ->       0,0,0,4,100
 QNDPQNDPQNDP   ->       3,3,3,3,123
 PPPPPPPPPP     ->       10,0,0,0,10
 PNNDNNQPDNPQND ->       3,6,3,2,113

Zasady

Standardowe luki są niedozwolone.

To jest , więc wygrywa najkrótszy kod w bajtach dla każdego języka!

DevelopingDeveloper
źródło
1
@Shaggy Tak, możesz
DevelopingDeveloper
1
Kolejność monet ogółem . Czy możemy podać go w kolejności pojawiania się na wejściu?
Adám
1
Więc jeśli kolejność można wywnioskować z danych wejściowych, czy możemy pominąć 0? Nadal będzie jasne, do których liter odnosi się każda liczba.
Adám
1
Czy ten format wyjściowy jest zbyt odległy? 19-bajtowa odpowiedź, że nie jestem pewien, czy jest poprawna: Wypróbuj online!
Magic Octopus Urn
1
Wydaje mi się, że powinien być tag [pieniędzy].
12Me21

Odpowiedzi:

5

Python 2 , 73 bajty

-3 bajty dzięki @Rod

C=map(input().count,'QDNP')
print C+[sum(map(int.__mul__,C,[25,10,5,1]))]

Wypróbuj online!

Dead Possum
źródło
4
Można wymienić a*b for a,b in zip(C,[25,10,5,1])z map(int.__mul__,C,[25,10,5,1])zaoszczędzić kilka bajtów
Rod
4

APL (Dyalog Unicode) , 28 27 bajtów

1 5 10 25(⊢,+.×)'PNDQ'+.=¨⊂

Wypróbuj online!

Funkcja milcząca. Pobiera dane wejściowe jako wektor w formacie ,'<input>'.

Dzięki ngn za jeden bajt!

W jaki sposób?

1 5 10 25(⊢,+.×)'PNDQ'+.=¨⊂  Main function, tacit.
                            Enclose
                         ¨   Each character of the input
                      +.=    Sum the number of matched characters
                'PNDQ'       From this string
1 5 10 25(  +.×)             Multiply the values with the left argument, then sum them.
          ⊢,                 And append to the original vector of coins.
J. Sallé
źródło
1⊥∘.=∘'PNDQ'->'PNDQ'+.=¨⊂
ngn
4

R , 70 69 bajtów

function(n)c(x<-table(factor(n,c("P","N","Q","D"))),x%*%c(1,5,25,10))

Wypróbuj online!

Pobiera dane wejściowe jako wektor poszczególnych znaków. Konwertuje je na factorsi tabulates, a następnie oblicza wartości za pomocą iloczynu kropkowego.

Dla ułatwienia testowania dodałem sposób konwersji z powyższych przypadków testowych na dane wejściowe, których oczekuje funkcja.

To ledwie przewyższa przechowywanie nazw monet jako wektorów names, co oznacza, że ​​poniższe podejście byłoby bardziej golfistyczne, gdybyśmy mieli więcej typów monet:

R , 71 70 bajtów

function(n)c(x<-table(factor(n,names(v<-c(P=1,N=5,Q=25,D=10)))),x%*%v)

Wypróbuj online!

Giuseppe
źródło
3

Galaretka , 19 bajtów

ċЀ“PNDQ”µæ.“¢¦½ı‘ṭ

Wypróbuj online!

Jak to działa

ċЀ“PNDQ”µæ.“¢¦½ı‘ṭ    Main link. Arguments: s (string)
 Ѐ“PNDQ”              For each char in "PNDQ":
ċ                        Count the occurrences of the char in s.
                       Collect the results in an array. Call this a.
         µ             Start a new monadic chain. Argument: a
          æ.           Take the dot product of a with
            “¢¦½ı‘       [1, 5, 10, 25].
                  ṭ    Tack this onto the end of a.
ETHprodukcje
źródło
3

JavaScript (ES6), 63 61 bajtów

Zaoszczędź 2 bajty dzięki Shaggy

Pobiera dane wejściowe jako tablicę znaków. Wyjścia P,N,D,Q,total.
Zainspirowany odpowiedzią Pythona na ovs .

a=>eval(a.join`++,`+`++,[P,N,D,Q,P+N*5+D*10+Q*25]`,P=N=D=Q=0)

Wypróbuj online!


Oryginalna odpowiedź, 73 bajty

Pobiera dane wejściowe jako tablicę znaków. Wyjścia Q,D,N,P,total.

a=>a.map(c=>o[o[4]+='521'[i='QDNP'.search(c)]*5||1,i]++,o=[0,0,0,0,0])&&o

Wypróbuj online!

Arnauld
źródło
Bardzo ładnie wykonane! Możesz zrzucić 2 bajty , tasując jakieś rzeczy.
Shaggy
3

MATL , 22 20 bajtów

!'PNDQ'=Xst[l5X25]*s

Wypróbuj online! Lub sprawdź wszystkie przypadki testowe .

Objaśnienie z przykładem

Rozważ dane wejściowe 'PNNDNNQPDNPQND'jako przykład. Zawartość stosu wyświetlana jest do góry nogami, tzn. Górny element pojawia się poniżej.

!        % Implicit input: string (row vector of chars). Transpose into a
         % column vector of chars
         % STACK: ['P';
                   'N';
                   'N';
                   'D';
                   'N';
                   'N';
                   'Q';
                   'P';
                   'D';
                   'N';
                   'P';
                   'Q';
                   'N';
                   'D']
'PNDQ'   % Push this string (row vector of chars)
         % STACK: ['P';
                   'N';
                   'N';
                   'D';
                   'N';
                   'N';
                   'Q';
                   'P';
                   'D';
                   'N';
                   'P';
                   'Q';
                   'N';
                   'D'],
                  'PNDQ'
=        % Implicit input. Test for equality, element-wise with broadcast
         % STACK: [1 0 0 0;
                   0 1 0 0;
                   0 1 0 0;
                   0 0 1 0;
                   0 1 0 0;
                   0 1 0 0;
                   0 0 0 1;
                   1 0 0 0;
                   0 0 1 0;
                   0 1 0 0;
                   1 0 0 0;
                   0 0 0 1;
                   0 1 0 0;
                   0 0 1 0]
Xs       % Sum of each column
         % STACK: [3 6 3 2]
t        % Duplicate
         % STACK: [3 6 3 2],
                  [3 6 3 2]
[l5X25]  % Push array [1 5 10 25]
         % STACK: [3 6 3 2],
                  [3 6 3 2],
                  [1 5 10 25]
*        % Multiply, element-wise
         % STACK: [3 6 3 2],
                  [3 30 30 50]
s        % Sum
         % STACK: [3 6 3 2],
                  113
         % Implicitly display
Luis Mendo
źródło
!'PNDQ'=Xst[l5X25]!Y*ma 21 bajtów. chociaż przyznaję, że go nie testowałem.
Giuseppe
@Giuseppe Dzięki, ale wyzwanie mówi „ wybrany przez ciebie niecałkowity ogranicznik”, więc zakładam, że dozwolony jest tylko jeden ogranicznik
Luis Mendo
Nie zauważyłem tego. Ach tak.
Giuseppe
1
Myślę, że 21 bajtowe rozwiązanie jest OK ... OP skomentował coś w tym celu
Giuseppe
@Giuseppe Świetnie! Następnie do 20 bajtów. Dzięki za heads-up
Luis Mendo
3

Japt , 25 22 bajtów

Zaoszczędź 3 bajty dzięki @Shaggy

`p˜q`¬£èX
pUí*38#éìH)x

Przetestuj online! Pobiera dane pisane małymi literami

Wyjaśnienie

`p˜q`¬         Split the compressed string "pndq" into chars, giving ["p", "n", "d", "q"].
      £        Map each char X to
       èX      the number of occurrences of X in the input.
<newline>      Set variable U to the resulting array.
 Uí*           Multiply each item in U by the corresponding item in
    38#é         38233
        ìH       converted to base-32, giving [1, 5, 10, 25].
           x   Take the sum.
p              Append this to the end of U.
               Implicit: output result of last expression
ETHprodukcje
źródło
Próbuję znaleźć sposób na odejście od przecinka, nie mając jak dotąd dużo szczęścia.
Shaggy
Rozumiem!
Shaggy
I zapisz kolejny bajt , wprowadzając małe litery.
Kudłaty
@Shaggy Imponujące, dzięki!
ETHprodukcje
3

Excel (polska wersja językowa), 150 bajtów

Dane wejściowe znajdują się w A1. Formuły znajdują się w komórkach B1- F1:

cell  formula
------------------------------
B1    =DŁ(A1)-DŁ(PODSTAW(A1;"Q";""))
C1    =DŁ(A1)-DŁ(PODSTAW(A1;"D";""))
D1    =DŁ(A1)-DŁ(PODSTAW(A1;"N";""))
E1    =DŁ(A1)-DŁ(PODSTAW(A1;"P";""))
F1    =B1*25+C1*10+D1*10+E1

w wyniku czego powstaje liczba kwartałów, dziesięciocentówek, nikli, centów i suma w komórkach B1 , C1, D1, E1i F1odpowiednio.

Wersja angielska (162 bajty):

cell  formula
------------------------------
B1    =LEN(A1)-LEN(SUBSTITUTE(A1;"Q";""))
C1    =LEN(A1)-LEN(SUBSTITUTE(A1;"D";""))
D1    =LEN(A1)-LEN(SUBSTITUTE(A1;"N";""))
E1    =LEN(A1)-LEN(SUBSTITUTE(A1;"P";""))
F1    =B1*25+C1*10+D1*10+E1
pajonk
źródło
3

APL + WIN, 33 27 bajtów

5 bajtów zaoszczędzonych dzięki Adamowi

Monity o wprowadzanie ekranu ciągu monet.

n,+/1 5 10 25×n←+⌿⎕∘.='PNDQ'
Graham
źródło
Zaoszczędź 5 bajtów:n,+/1 5 10 25×n←+⌿⎕∘.='PNDQ'
Adám
@ngn Thanks. Starość staje się lepsza ode mnie :(
Graham,
2

05AB1E , 30 26 22 21 19 bajtów

X5T25)s.•50†•S¢=*O=

Wypróbuj online!


X                   # Push 1.
 5                  # Push 5.
  T                 # Push 10.
   25               # Push 25.
     )s             # Wrap stack to array, swap with input.
       .•50†•       # Push 'pndq'.
             S      # Push ['p','n','d','q'] (split).
              ¢     # Count (vectorized).
               =    # Print counts, without popping.
                *   # Multiply counts by [1,2,10,25]
                 O  # Sum.
                  = # Print.

Wysypisko:

Full program: X5T25)s.•50†•S¢=*O=
current >> X  ||  stack: []
current >> 5  ||  stack: [1]
current >> T  ||  stack: [1, '5']
current >> 2  ||  stack: [1, '5', 10]
current >> )  ||  stack: [1, '5', 10, '25']
current >> s  ||  stack: [[1, '5', 10, '25']]
current >> .  ||  stack: [[1, '5', 10, '25'], 'pnndnnqpdnpq']
current >> S  ||  stack: [[1, '5', 10, '25'], 'pnndnnqpdnpq', 'pndq']
current >> ¢  ||  stack: [[1, '5', 10, '25'], 'pnndnnqpdnpq', ['p', 'n', 'd', 'q']]
current >> =  ||  stack: [[1, '5', 10, '25'], [3, 5, 2, 2]]
[3, 5, 2, 2]
current >> *  ||  stack: [[1, '5', 10, '25'], [3, 5, 2, 2]]
current >> O  ||  stack: [[3, 25, 20, 50]]
current >> =  ||  stack: [98]
98
stack > [98]

Wydruk:

[3, 25, 20, 50]\n98 or [P, N, D, Q]\n<Sum>

Ponieważ coś zostało wydrukowane, stos końcowy jest ignorowany.

Urna Magicznej Ośmiornicy
źródło
2

J , 29 bajtów

1 5 10 25(],1#.*)1#.'PNDQ'=/]

Wypróbuj online!

Wyjaśnienie:

'PNDQ'=/] tworzy tabelę równości

   'PNDQ' =/ 'PNNDNNQPDNPQND'
1 0 0 0 0 0 0 1 0 0 1 0 0 0
0 1 1 0 1 1 0 0 0 1 0 0 1 0
0 0 0 1 0 0 0 0 1 0 0 0 0 1
0 0 0 0 0 0 1 0 0 0 0 1 0 0

1#. znajduje sumę każdego wiersza tabeli, a tym samym liczbę wystąpień każdej wartości

   1#. 'PNDQ' =/ 'PNNDNNQPDNPQND'
3 6 3 2

1#.* znajduje iloczyn skalarny argumentu lewego i prawego

    1 5 10 25(1#.*)3 6 3 2
113

], dołącza iloczyn skalarny do listy wartości

   1 5 10 25(],1#.*)1#.'PNDQ'=/] 'PNNDNNQPDNPQND'
3 6 3 2 113
Galen Iwanow
źródło
2

C # (.NET Core) , 163 136 bajtów

Dzięki @raznagul za uratowanie wielu bajtów!

n=>{var m="";int c=0,i=0,k=0;for(var v=new[]{1,5,10,25};i<4;m+=k+",",c+=k*v[i++],k=0)foreach(var x in n)k+=x=="PNDQ"[i]?1:0;return m+c;}

Wypróbuj online!


Stara wersja:

n=>{var v=new[]{1,5,10,25};string l="PNDQ",m="";int c=0,i,j,k;for(i=0;i<4;i++){for(j=0,k=0;j<n.Length;j++)k+=n[j]==l[i]?1:0;m+=k+",";c+=k*v[i];k=0;}m+=c;return m;}

Wypróbuj online!

Ian H.
źródło
1
Udało mi się zagrać w golfa w twoją duszę do 136 bajtów . Do wielu zmian na liście.
raznagul
@raznagul Świetne rozwiązanie! Czy mogę zapytać, dlaczego zmieniłeś dane wejściowe na ogólną listę zamiast tablicy? AFAIK możesz iterować po znakach ciągu bez korzystania z listy.
Ian H.
To pozostałość po wcześniejszej wersji, więc mógłbym użyć n.Countzamiast n.Length. Ponieważ został on całkowicie usunięty, możesz go stringteraz używać .
raznagul
1

Perl 5 -pF , 59 bajtów

for$i(P,N,D,Q){say s:$i:$\+={P,1,Q,25,D,10,N,5}->{$&}:eg}}{

Wypróbuj online!

Xcali
źródło
1

Rubin , 66 bajtów

->s{t=0;{P:1,N:5,D:10,Q:25}.map{|c,v|t+=v*m=s.count(c.to_s);m}<<t}

Wypróbuj online!

Nie najlepiej.

Przywróć Monikę - notmaynard
źródło
1

05AB1E , 19 bajtów

"PNDQ"S¢D•Ωт•₂в*O)˜

Wypróbuj online!

Wyjaśnienie

"PNDQ"                # push this string
      S               # split to list of chars
       ¢              # count the occurrences of each in input
        D             # duplicate
         •Ωт•         # push 21241
             ₂в       # convert to a list of base 26 digits
               *      # element-wise multiplication
                O     # sum
                 )˜   # wrap in a flattened list
Emigna
źródło
1

Java (OpenJDK 8) , 148 bajtów

c->{int q=0,d=0,n=0,p=0;for(char w:c){if(w=='Q')q++;if(w=='D')d++;if(w=='N')n++;if(w=='P')p++;}return ""+q+","+d+","+n+","+p+","+(q*25+d*10+n*5+p);}

Wypróbuj online!

Cóż, jest tylko jeden bajt krótszy niż inne przesłanie Javy, ale hej krótszy jest krótszy: D

Wyjaśnienie:

int q=0,d=0,n=0,p=0;    //Initialize too many integers
for(char w:c){    //Loop through each coin
  if(w=='Q')q++;if(w=='D')d++;if(w=='N')n++;if(w=='P')p++;    //Increment the correct coin
}return ""+q+","+d+","+n+","+p+","+(q*25+d*10+n*5+p);    //Return each coin count and the total monetary value 
X1M4L
źródło
143 bajty
ceilingcat
1

Gol> <> , 47 bajtów

5R0TiE!vD;
5+@P@@t>b%m$.
a+$P$t
PrPrt
9s+r$P$rt

Wypróbuj online!

Format wyjściowy to [P Q N D Value].

Jak to działa

5R0TiE!vD;
       >b%m$.

5R0            Repeat command '0' (push 0) 5 times
   T           Set teleport location for later
    i          Input a char
     E         Pop if the last input was EOF; skip next otherwise

               If the last is EOF, the following is run:
      ! D;     Skip 'v', print the contents of the stack from bottom to top, then exit

               Otherwise the following is run:
       v
       >b%m$.  Take the top (input) modulo 11, and jump to (-1, input % 11)
               P%11 = 3, N%11 = 1, D%11 = 2, Q%11 = 4

5+@P@@t        Runs if the input is N
5+             Add 5 to top
  @            Rotate top 3 (the 3rd comes to the top)
   P           Increment the top
  @P@@         Increment the 3rd from top
      t        Teleport to the last 'T'

a+$P$t         Runs if the input is D
a+             Add 10 to top
  $            Swap top two
  $P$          Increment the 2nd from top
     t         Teleport to the last 'T'

PrPrt          Runs if the input is P
P              Increment the top
 r             Reverse the stack
 rPr           Increment the bottom
    t          Teleport to the last 'T'

9s+r$P$rt      Runs if the input is Q
9s+            Add 25 to the top ('s': add 16 to the top)
   r$P$r       Increment the 2nd from bottom
        t      Teleport to the last 'T'
Bubbler
źródło
1

Pyth, 23 27 26 bajtów

+Jm/Qd"PNDQ"s.b*NYJ[h05T25

Zapisano bajt dzięki @RK. Wykazuje jako [P, N, D, Q, wartość].
Wypróbuj tutaj

Wyjaśnienie

+Jm/Qd"PNDQ"s.b*NYJ[h05T25
 Jm/Qd"PNDQ"                Save the count of each coin (in PNDQ order) as J.
                   [h05T25  [1, 5, 10, 25].
             .b   J       For each pair of count and value...
               *NY          ... take the product...
            s               ... and get the sum.
+                          Stick that onto the list of counts.

źródło
Możesz skondensować definicję J i pierwsze użycie J, aby uzyskać+Jm/Qd"PNDQ"s.b*NYJ[h05T25
RK.
1

C (brzęk) , 112 bajtów

f(char *i){int c,d,v[5]={0};for(;c=*i++;v[d=(c|c/2)&3]++,v[4]+="AYJE"[d]-64);for(c=0;c<5;printf("%d,",v[c++]));}

Wypróbuj online!

Sekwencja wyjściowa ma teraz P, Q, D, N, wartość całkowita
Działa zarówno z małymi, jak i dużymi wejściami.

Wyjaśnienie:

"AYJE"lub {64+1,64+25,64+10,64+5}jest. 64 + wartość monety.
d=(c|c/2)&3(stosowany jako indeks) ma odpowiednio wartość 1,2,3,0dla q,d,n,pdanych wejściowych, zarówno dużymi, jak i małymi literami.

GPS
źródło
106 bajtów
pułapcatcat
Wyeliminowanie c = 0 było dobrym chwytem. Dzięki.
GPS
0

C # (.NET Core) , 156 bajtów

s=>{Func<char,int>f=i=>{return s.Split(i).Length-1;};var a=new[]{f('P'),f('N'),f('D'),f('Q')};return$"{string.Join(",",a)},{a[0]+a[1]*5+a[2]*10+a[3]*25}";};
Romen
źródło
0

Siatkówka , 50 bajtów

P
P_
N
N5*
D
D10*
Q
Q25*
^
PNDQ_
O`.
(.)(\1*)
$.2¶

Wypróbuj online! Wyjścia w kolejności D, N, P, Q, ogółem. Wyjaśnienie:

P
P_
N
N5*
D
D10*
Q
Q25*

Oblicz sumę, wstawiając _s odpowiadające wartości każdej monety.

^
PNDQ_

Wstaw dodatkową kopię każdego znaku, aby było co najmniej jedno dopasowanie.

O`.

Sortuj znaki w kolejności.

(.)(\1*)
$.2¶

Policz liczbę każdego znaku po pierwszym.

Neil
źródło
0

SmileBASIC, 70 bajtów

INPUT C$P=N+D+Q
WHILE""<C$INC VAR(POP(C$))WEND?P,N,D,Q,P+N*5+D*10+Q*25

Przykład:

? PNDNDNDQP
2   3   3   1   72

Wyjaśnienie:

INPUT COINS$
P=N+D+Q 'create variables
WHILE COINS$>"" 'loop until the coin list is empty
 'pop a character from the coin list
 'and increment the variable with that name
 INC VAR(POP(COINS$))
WEND
PRINT P,N,D,Q,P+N*5+D*10+Q*25
12Me21
źródło
0

C, 149 bajtów

f(char*s){int a[81]={},b[]={1,5,10,25},c=0;char*t,*v="PNDQ";for(t=s;*t;a[*t++]++);for(t=v;*t;printf("%d,",a[*t++]))c+=a[*t]*b[t-v];printf("%d\n",c);}

Wypróbuj online!

C nie ma tablic asocjacyjnych, więc sfałszowałem go (bardzo nieefektywnie, pod względem pamięci!), A następnie ponownie przejrzałem tablicę odnośników, aby dodać monety. Nie obliczy jednak waluty obcej :-)

ErikF
źródło
133 bajty
ceilingcat