Mealheiro eletrônico


11

Um cofrinho é um contêiner usado para coletar moedas. Para esse desafio, use as quatro moedas dos EUA: quarto, centavo, níquel e centavo .

Desafio

Seu desafio é criar um cofrinho eletrônico. Escreva um programa (ou função) que, quando executado (ou chamado), produz (ou retorna) a contagem de cada moeda que você possui, bem como a quantidade total que as moedas equivalem.

Entrada

Uma string, array, etc ... (sua escolha) das moedas no seu cofrinho (não diferencia maiúsculas de minúsculas).

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

Resultado

A contagem de moedas da entrada e a quantidade total, separadas pelo delimitador não inteiro de sua escolha. (A ordem na qual você produz os totais da moeda não importa, mas o valor total da moeda (soma) deve ser o último elemento)

Exemplos

 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

Regras

As brechas padrão não são permitidas.

Isso é , então o código mais curto em bytes para cada idioma vence!


1
@Shaggy Sim, você pode
DevelopingDeveloper

1
A ordem das moedas no total . Podemos dar na ordem de aparência na entrada?
Adám 29/03/19

1
Portanto, se a ordem pode ser inferida a partir da entrada, podemos omitir 0s? Ainda ficará claro a quais letras o número se refere.
Adám 29/03/18

1
Esse formato de saída está muito distante? Resposta de 19 bytes que não tenho certeza é válida: Experimente on-line!
Urna de polvo mágico

1
Eu sinto que deveria haver uma etiqueta [dinheiro].
12Me21

Respostas:


5

Python 2 , 73 bytes

-3 bytes graças a @Rod

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

Experimente online!


4
Você pode substituir a*b for a,b in zip(C,[25,10,5,1])por map(int.__mul__,C,[25,10,5,1])para economizar alguns bytes
Rod


4

APL (Dyalog Unicode) , 28 27 bytes

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

Experimente online!

Função tácita. Recebe entrada como um vetor no formato ,'<input>'.

Graças a ngn por um byte!

Quão?

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.

1⊥∘.=∘'PNDQ'->'PNDQ'+.=¨⊂
NGN

4

R , 70 69 bytes

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

Experimente online!

Recebe entrada como um vetor de caracteres individuais. Converte-os em es factorse tabulate, em seguida, calcula os valores com um produto escalar.

Para facilitar os propósitos de teste, adicionei uma maneira de converter os casos de teste acima na entrada que a função espera.

Isso dificilmente supera armazenar os nomes das moedas como vetor names, o que significa que a abordagem abaixo provavelmente seria mais golfista se tivéssemos mais tipos de moedas:

R , 71 70 bytes

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

Experimente online!


3

Geléia , 19 bytes

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

Experimente online!

Como funciona

ċЀ“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.

3

JavaScript (ES6), 63 61 bytes

Economizou 2 bytes graças a Shaggy

Recebe a entrada como uma matriz de caracteres. Saídas P,N,D,Q,total.
Inspirado pela resposta Python dos ovs .

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

Experimente online!


Resposta original, 73 bytes

Recebe a entrada como uma matriz de caracteres. Saídas 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

Experimente online!


Muito bem feito! Você pode eliminar 2 bytes embaralhando algumas coisas.
Shaggy

3

MATL , 22 20 bytes

!'PNDQ'=Xst[l5X25]*s

Experimente online! Ou verifique todos os casos de teste .

Explicação com exemplo

Considere a entrada 'PNNDNNQPDNPQND'como um exemplo. O conteúdo da pilha é mostrado de cabeça para baixo, ou seja, o elemento superior aparece abaixo.

!        % 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

!'PNDQ'=Xst[l5X25]!Y*tem 21 bytes. embora eu admita que não testei.
Giuseppe

@Giuseppe Graças, mas o desafio diz " o delimitador não inteiro de sua escolha", assim que eu supor apenas um delimitador é permitido
Luis Mendo

Eu não tinha notado isso. Ah bem.
Giuseppe

1
Acho que a solução 21 byte é OK ... OP comentou algo nesse sentido
Giuseppe

@Giuseppe Great! Abaixo de 20 bytes então. Obrigado pelo alerta
Luis Mendo

3

Japonês , 25 22 bytes

Guardado 3 bytes graças a @Shaggy

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

Teste online! Recebe entrada em minúsculas

Explicação

`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

Tentando descobrir uma maneira de jogar fora a vírgula, sem ter muita sorte até agora.
Shaggy


E salve outro byte , digitando em minúsculas.
Shaggy


@ Shaggy Impressive, obrigado!
ETHproductions

3

Excel (versão em polonês), 150 bytes

A entrada está em A1. As fórmulas estão nas células 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

resultando na produção de vários quadrantes, moedas, niquelar, pennys e a soma em células B1, C1, D1, E1e F1, respectivamente.

Versão em inglês (162 bytes):

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

3

APL + WIN, 33 27 bytes

5 bytes salvos graças a Adam

Solicita a entrada da tela da sequência de moedas.

n,+/1 5 10 25×n←+⌿⎕∘.='PNDQ'

Salvar 5 bytes:n,+/1 5 10 25×n←+⌿⎕∘.='PNDQ'
Adám

@ngn Obrigado. A velhice está tirando o melhor de mim :(
Graham

2

05AB1E , 30 26 22 21 19 bytes

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

Experimente 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.

Despejo:

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]

Saída impressa:

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

Como algo foi impresso, a pilha final é ignorada.


2

J , 29 bytes

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

Experimente online!

Explicação:

'PNDQ'=/] cria uma tabela de igualdade

   '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#. encontra a soma de cada linha da tabela, portanto, o número de ocorrências de cada valor

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

1#.* encontra o produto escalar de seu argumento esquerdo e direito

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

], anexa o produto escalar à lista de valores

   1 5 10 25(],1#.*)1#.'PNDQ'=/] 'PNNDNNQPDNPQND'
3 6 3 2 113

2

C # (.NET Core) , 163 136 bytes

Obrigado a @raznagul por salvar muitos bytes por lá!

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;}

Experimente online!


Versão antiga:

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;}

Experimente online!


1
Eu consegui jogar sua soultion em até 136 bytes . Para muitas mudanças na lista.
raznagul

@raznagul Ótima solução! Posso perguntar por que você alterou a entrada para uma lista genérica em vez de uma matriz? AFAIK, você pode iterar sobre os caracteres de uma sequência sem usar uma lista.
Ian H.

Isso é um remanescente de uma versão anterior, então eu poderia usar em n.Countvez de n.Length. Como isso foi descartado completamente, você pode usar stringagora.
raznagul



1

05AB1E , 19 bytes

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

Experimente online!

Explicação

"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

1

Java (OpenJDK 8) , 148 bytes

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);}

Experimente online!

Bem, é apenas um byte mais curto que o outro envio Java, mas, ei, menor é menor: D

Explicação:

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 


1

Gol> <> , 47 bytes

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

Experimente online!

O formato de saída é [P Q N D Value].

Como funciona

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'


1

Pitão, 23 27 26 bytes

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

Guardou um byte graças a @RK. Saídas como [P, N, D, Q, valor].
Experimente aqui

Explicação

+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.

Você pode condensar a definição de J e o primeiro uso de J para obter+Jm/Qd"PNDQ"s.b*NYJ[h05T25
RK.

1

C (clang) , 112 bytes

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++]));}

Experimente online!

A saída seq é agora de P, Q, D, N, valor total
Funciona com entradas em minúsculas e maiúsculas.

Explicação:

"AYJE"ou {64+1,64+25,64+10,64+5}é. 64 + valor da moeda.
d=(c|c/2)&3(usado como índice) possui valor 1,2,3,0para q,d,n,pentradas, respectivamente, em maiúsculas e minúsculas.



Eliminar c = 0 foi uma boa captura. Obrigado.
GPS

0

C # (.NET Core) , 156 bytes

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}";};


0

Retina , 50 bytes

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

Experimente online! Saídas na ordem D, N, P, Q, total. Explicação:

P
P_
N
N5*
D
D10*
Q
Q25*

Calcule o total inserindo _s correspondente ao valor de cada moeda.

^
PNDQ_

Insira uma cópia extra de cada caractere para que haja pelo menos um de cada um para corresponder.

O`.

Classifique os caracteres em ordem.

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

Conte o número de cada caractere após o primeiro.


0

SmileBASIC, 70 bytes

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

Exemplo:

? PNDNDNDQP
2   3   3   1   72

Explicação:

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

0

C, 149 bytes

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);}

Experimente online!

C não possui matrizes associativas, então eu as falsifico (de maneira ineficiente, em memória!) E depois repito novamente com uma matriz de pesquisa para somar as moedas. Porém, ele não calcula moeda estrangeira :-)


Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.