Электронная Копилка

11

Копилки представляет собой контейнер , используемый для сбора монет Для этой задачи использовать четыре американских монет:. Четверть, десять центов, никель и пенни .

Вызов

Ваша задача - создать электронную копилку. Напишите программу (или функцию), которая при запуске (или вызове) выводит (или возвращает) количество каждой вашей монеты, а также общее количество монет.

вход

Строка, массив и т.д ... (на ваш выбор) монет в вашу копилку (без учета регистра).

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

Выход

Количество монет на входе и общая сумма, разделенные нецелым разделителем по вашему выбору. (Порядок, в котором вы выводите итоговые суммы монет, не имеет значения, но итоговый элемент монеты (сумма) должен быть последним элементом)

Примеры

 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

правила

Стандартные лазейки не допускаются.

Это , поэтому выигрывает самый короткий код в байтах для каждого языка!

DevelopingDeveloper
источник
1
@ Shaggy Да, вы можете
DevelopingDeveloper
1
Порядок монет в общем . Можем ли мы привести его в порядке появления на входе?
Адам
1
Так что, если порядок может быть выведен из ввода, можем ли мы опустить 0? Будет еще понятно, к каким буквам относится каждое число.
Адам
1
Этот формат вывода слишком далеко? 19-байтный ответ, который я не уверен, действителен: попробуйте онлайн!
Волшебный Осьминог Урна
1
Я чувствую, что должен быть тег [money].
12Me21

Ответы:

5

Python 2 , 73 байта

-3 байта благодаря @Rod

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

Попробуйте онлайн!

Мертвый Опоссум
источник
4
Вы можете заменить a*b for a,b in zip(C,[25,10,5,1])на, map(int.__mul__,C,[25,10,5,1])чтобы сохранить несколько байтов
Rod
4

APL (Dyalog Unicode) , 28 27 байтов

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

Попробуйте онлайн!

Молчаливая функция. Принимает ввод как вектор в формате ,'<input>'.

Спасибо ngn за один байт!

Как?

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 байт

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

Попробуйте онлайн!

Принимает ввод как вектор отдельных символов. Преобразует их в factorsи tabulates их, затем вычисляет значения с точечным произведением.

Для удобства тестирования я добавил способ преобразования приведенных выше тестовых примеров во входные данные, ожидаемые функцией.

Это практически исключает сохранение имен монет в качестве вектора names, что означает, что подход, приведенный ниже, скорее всего, будет более удачным, если у нас будет больше типов монет:

R , 71 70 байт

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

Попробуйте онлайн!

Giuseppe
источник
3

Желе , 19 байт

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

Попробуйте онлайн!

Как это работает

ċЀ“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.
ETHproductions
источник
3

JavaScript (ES6), 63 61 байт

Сохранено 2 байта благодаря Shaggy

Принимает ввод как массив символов. Выходы P,N,D,Q,total.
Вдохновленный ответом Python от ovs .

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

Попробуйте онлайн!


Оригинальный ответ, 73 байта

Принимает ввод как массив символов. Выходы 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

Попробуйте онлайн!

Arnauld
источник
Очень красиво сделано! Вы можете сбить 2 байта , перетасовывая некоторые вещи вокруг.
Лохматый
3

MATL , 22 20 байт

!'PNDQ'=Xst[l5X25]*s

Попробуйте онлайн! Или проверьте все тестовые случаи .

Пояснение с примером

Рассмотрим ввод 'PNNDNNQPDNPQND'в качестве примера. Содержимое стека отображается вверх ногами, то есть верхний элемент отображается ниже.

!        % 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*составляет 21 байт. хотя я признаю, что я не проверял это.
Джузеппе
@Giuseppe Спасибо, но проблема говорит « нецелый ограничитель вашего выбора», поэтому я полагаю , только один разделитель разрешен
Луис Mendo
Я этого не заметил. Ах хорошо.
Джузеппе
1
Я думаю, что 21-байтовое решение в порядке ... ОП прокомментировал что-то на этот счет
Джузеппе
@ Джузеппе Отлично! Тогда до 20 байтов. Спасибо за хедз-ап
Луис Мендо
3

Japt , 25 22 байта

Сохранено 3 байта благодаря @Shaggy

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

Проверьте это онлайн! Принимает ввод в нижнем регистре

объяснение

`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
ETHproductions
источник
Пытаюсь найти способ запутаться в гольфе, пока не повезло.
Лохматый
Понял!
Лохматый
И сохраните еще один байт , введя строчные буквы.
Лохматый
@ Shaggy Впечатляет, спасибо!
ETHproductions
3

Excel (версия на польском языке), 150 байт

Вход в А1. Формулы в клетках 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

что приводит к выходу из числа четвертей, пятаков, никелевые, Pennys и суммы в клетках B1, C1, D1, E1и F1соответственно.

Английская версия (162 байта):

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
источник
3

APL + WIN, 33 27 байт

5 байтов сохранено благодаря Адаму

Запрашивает ввод на экран строки монеты.

n,+/1 5 10 25×n←+⌿⎕∘.='PNDQ'
Грэхем
источник
Сохраните 5 байтов:n,+/1 5 10 25×n←+⌿⎕∘.='PNDQ'
Адам
@ngn Спасибо. Старость становится лучше меня :(
Грэм,
2

05AB1E , 30 26 22 21 19 байтов

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

Попробуйте онлайн!


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.

Dump:

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]

Печатная продукция:

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

Поскольку что-то было напечатано, конечный стек игнорируется.

Урна волшебного осьминога
источник
2

J , 29 байт

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

Попробуйте онлайн!

Объяснение:

'PNDQ'=/] создает таблицу равенства

   '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#. находит сумму каждой строки таблицы, таким образом, количество вхождений каждого значения

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

1#.* находит скалярное произведение своего левого и правого аргумента

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

], добавляет точечное произведение в список значений

   1 5 10 25(],1#.*)1#.'PNDQ'=/] 'PNNDNNQPDNPQND'
3 6 3 2 113
Гален Иванов
источник
2

C # (.NET Core) , 163 136 байт

Спасибо @raznagul за сохранение большого количества байтов!

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

Попробуйте онлайн!


Старая версия:

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

Попробуйте онлайн!

Ян Х.
источник
1
Мне удалось довести свою душу до 136 байтов . Для многих изменений в списке.
Разнагул
@raznagul Отличное решение! Могу я спросить, почему вы переключили вход в общий список вместо массива? AFAIK вы можете перебирать символы строки без использования списка.
Ян Х.
Это остаток от более ранней версии, поэтому я мог бы использовать n.Countвместо n.Length. Поскольку это было отброшено полностью, вы можете использовать stringсейчас.
Разнагул
1

05AB1E , 19 байтов

"PNDQ"S¢D•Ωт•₂в*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
Emigna
источник
1

Java (OpenJDK 8) , 148 байт

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

Попробуйте онлайн!

Ну, это всего на один байт короче, чем другие представления Java, но хей-короче короче: D

Объяснение:

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
источник
143 байта
floorcat
1

Gol> <> , 47 байт

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

Попробуйте онлайн!

Выходной формат [P Q N D Value].

Как это работает

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

Pyth, 23 27 26 байт

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

Сохраненный байт благодаря @RK. Выходы как [P, N, D, Q, значение].
Попробуй здесь

объяснение

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

источник
Вы можете сжать определение J и первое использование J, чтобы получить+Jm/Qd"PNDQ"s.b*NYJ[h05T25
RK.
1

C (лязг) , 112 байт

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

Попробуйте онлайн!

Выходной seq теперь имеет значения P, Q, D, N, общее значение.
Работает как со строчными, так и со строчными вводами.

Объяснение:

"AYJE"или {64+1,64+25,64+10,64+5}есть. 64 + значение-из-монеты.
d=(c|c/2)&3(используется как индекс) имеет значение 1,2,3,0для q,d,n,pвходов соответственно, как в верхнем, так и в нижнем регистре.

GPS
источник
106 байт
floorcat
Устранение c = 0 было хорошим уловом. Спасибо.
GPS
0

C # (.NET Core) , 156 байт

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

Сетчатка , 50 байт

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

Попробуйте онлайн! Выходы в порядке D, N, P, Q, всего. Объяснение:

P
P_
N
N5*
D
D10*
Q
Q25*

Рассчитайте сумму, вставив _s, соответствующий стоимости каждой монеты.

^
PNDQ_

Вставьте дополнительную копию каждого символа, чтобы был хотя бы один из них для сопоставления.

O`.

Сортировка символов в порядке.

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

Подсчитайте количество каждого символа после первого.

Нил
источник
0

SmileBASIC, 70 байт

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

Пример:

? PNDNDNDQP
2   3   3   1   72

Объяснение:

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
источник
0

C, 149 байтов

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

Попробуйте онлайн!

C не имеет ассоциативных массивов, поэтому я имитирую это (очень неэффективно, с точки зрения памяти!), А затем снова перебираю с помощью поискового массива, чтобы сложить монеты. Это не будет рассчитывать иностранную валюту, однако :-)

ErikF
источник
133 байта
floorcat