Quanto tempo meu microondas deve funcionar?

33

Eu estou com fome. Vamos microondas alguma coisa. Dada uma entrada numérica entre 1 e 4 dígitos, produza o número de segundos que o microondas deve funcionar.

Detalhes

O truque é descobrir se o usuário está inserindo segundos ou uma combinação de segundos e minutos. Os locais das dezenas e dezenas devem ser interpretados como segundos e as centenas e milhares de locais devem ser minutos. Por exemplo, o valor 1234deve ser interpretado como 12 minutos, 34 segundos e 9876deve ser 98 minutos, 76 segundos. Digitando 130e 90ambos devem resultar em um tempo de cozedura de 90 segundos.

Aqui estão algumas outras entradas e saídas:

  • 1 = 1
  • 11 = 11
  • 111 = 71
  • 1111 = 671
  • 9 = 9
  • 99 = 99
  • 999 = 639
  • 9999 = 6039

Regras

Isso é , então o programa mais curto em bytes vence. As brechas padrão não são permitidas. A entrada vencedora deve retornar a resposta correta quando receber uma entrada inteira de 1 a 9999.

Andrew Brēza
fonte
@ WheatWizard, estou feliz em editar a pergunta. Você tem alguma sugestão para o que devo dizer na seção Detalhes? Talvez eu possa deixar essa frase mais clara: "Os lugares e as dezenas devem ser interpretados como segundos e as centenas e milhares de lugares devem ser minutos".
Andrew Brēza 11/11/19
@ WheatWizard Acabei de adicionar mais detalhes, deixe-me saber se você acha que devo adicionar mais.
Andrew Brēza 11/11/19
Isso funciona com uma entrada de 9876?
Andrew Brēza 11/11/19
1
Estranho, eu estava prestes a sandbox este desafio exata haha
FlipTack
Para que serviria a saída 190?
OldBunny2800

Respostas:

9

Japonês , 6 bytes

ìL ì60

Teste online! ìLconverte em base-100 e ì60volta a base 60, resultando em floor(n/100)*60 + n%100. Também funciona com horas ( 10000 -> 3600, o número de segundos em uma hora).

ETHproductions
fonte
1
Exatamente o que eu tinha :) #
1178 Shaggy
7

C, C ++, Java, C #, D: 36 bytes

D: 35 bytes

C: 28 bytes

Primeira vez que tenho uma resposta curta!

int r(int i){return i/100*60+i%100;}

D pode ter uma otimização especial por causa do sistema de modelos de golfe:

T r(T)(T i){return i/100*60+i%100;}

C tem uma otimização especial com o int implícito:

r(i){return i/100*60+i%100;}

Código a testar

Em C (tem que incluir stdio.h):

int main() {
    int testArr[] = {1,11,111,1111,9,99,999,9999};
    for(int i=0;i<8; ++i) {
        printf("%d = %d\n",testArr[i],r(testArr[i]));
    }
    return 0;
}

Link TIO

Em C ++ (tem que incluir iostream):

int main() {
    std::initializer_list<int> testList{
        1,11,111,1111,9,99,999,9999
    };

    for (auto x : testList) {
        std::cout << r(x) << '\n';
    }
}

Experimente online!

Em Java :

public class MainApp {

    int r(int i){return i/100*60+i%100;}

    public static void main(String[]a) {
        MainApp m = new MainApp();
        int testArr[] = new int[]{
                1,11,111,1111,9,99,999,9999
        };

        for (int v : testArr) {
            System.out.println(v + " = " + m.r(v));
        }
    }
}

Experimente online!

Em c #

class Program {
    int r(int i){return i/100*60+i%100;}
    static void Main(string[] args) {
        var p = new Program();
        int[] testArr = new int[8]
        {
            1,11,111,1111,9,99,999,9999
        };
        foreach(int a in testArr) {
            Console.WriteLine(a + " = " + p.r(a));
        }
    }
}

Em D (tem que importar std.stdio) (exatamente, eu não tenho idéia de como usar matrizes em D):

void main() {
    int[] arr = [1,11,111,1111,9,9,999,9999];
    for(int i = 0; i < arr.length; i++)
        writeln(arr[i]," = ",r(arr[i]));
} 

Link TIO

HatsuPointerKun
fonte
O código de teste D é o rodapé deste TIO: tio.run/… , e vejo que você aprendeu o sistema de modelos :). (Há um foreachem D, eu esqueci como usá-lo, infelizmente)
Zachary
C pode ser convertido em golfe para 28 bytes usando C89 implicit-int.
pizzapants184
Você deve postar tudo isso como respostas separadas.
MD XF
6

Pitão - 9 8 bytes

Converte a entrada na base 100 e a interpreta como um número base 60.

ijQ*TT60

Conjunto de Teste .

Maltysen
fonte
6

TI-Basic (série 83), 8 bytes

Ans-40int(sub(Ans

Requer o SO versão 1.15 ou superior.

Misha Lavrov
fonte
6

dc , 10 bytes

?9A~r60*+p

Experimente online!

Explicação: em dc quando você pressiona sth. na pilha vai por cima

?         # read and push the input number on the stack
9A        # push 100: 9 * 10^1 + A[10] * 10^0 :D
~         # divide 2nd nr. by the top nr., push quotient, then remainder
r60*      # swap top 2 nr., then multiply the top by 60
+p        # add top 2 nr., then print result
seshoumara
fonte
5

Bash bc + sed, 30 28 bytes

-2 bytes graças a @seshoumara .

bc<<<0`sed 's/..\?$/*60+&/'`

Experimente online!

Recebe entrada de stdin. Adotou uma abordagem mais criativa: insere *60+antes dos últimos 1 ou 2 dígitos e precede 0a ao início para contabilizar entradas com apenas 1 ou 2 dígitos. O resultado é então passado para bc.

Justin Mariner
fonte
1
Se você remover -re usar \?, poderá perder 2 bytes.
seshoumara
3

Perl 5, 15 + 1 (-p) bytes

/..$/;$_-=40*$`
  • -l switch não é contado porque para legibilidade dos testes

Experimente online

Nahuel Fouilleul
fonte
2

JavaScript, 21 bytes

a=>(a/100^0)*60+a%100

Experimente online!


fonte
Salve 4 bytes usando o truque de ovs - a- (a / 100 ^ 0) * 40 #
IanF1 11/11
1
@ IanF1. Obrigado, mas acho que seria literalmente roubar a ideia deles.
Sim você está certo. Muito entusiasmado, desculpe.
IanF1
3
@ThePirateBay Você realmente não viver até o seu nome então;)
kamoroso94
2

J , 12 bytes

-40*&<.%&100

É a solução Python 2 da ovs, expressa em J. Consiste em um gancho e um garfo:

┌─┬───────────────────────┐
│-│┌──┬────────┬─────────┐│
│ ││40│┌─┬─┬──┐│┌─┬─┬───┐││
│ ││  ││*│&│<.│││%│&│100│││
│ ││  │└─┴─┴──┘│└─┴─┴───┘││
│ │└──┴────────┴─────────┘│
└─┴───────────────────────┘

       %&100  - divides the number by 100
   *&<.       - finds the floor of the left argument and multiplies it to the left arg.
 40           - 
-             - subtracts the result of the above fork from the input 

Experimente online!

Galen Ivanov
fonte
1
Contagem de mesmos bytes que 60#.0 100#:].
FrownyFrog
@FrownyFrog - sua solução parece mais bonita, felicidades!
Galen Ivanov
2

Lote, 23 bytes

@cmd/cset/a%1-%1/100*40
Neil
fonte
2

Haskell , 18 bytes

f t=t-t`div`100*40

Experimente online!

Porto Anotha.

Solução sem ponto, 21 bytes

(-)<*>(*40).(`div`40)
totalmente humano
fonte
2

Labirinto , 19 bytes

?:_100%}#00/_60*{+!

Experimente online!

Explicação

?      Read input.
:      Duplicate.
_100%  Mod 100.
}      Move off to auxiliary stack.
#00/   Divide by 100, using the stack depth to get a 1, instead of _1.
_60*   Multiply by 60.
{+     Retrieve the earlier result and add it.
!      Print.

O IP atinge um beco sem saída e começa a retroceder. Quando chega ao /, tenta uma divisão por zero que finaliza o programa.

Martin Ender
fonte
2

Gelatina , 5 bytes

Como um link monádico (obrigado pelo alerta, caird!):

b³ḅ60

Experimente online!

... Ou como um programa completo:

bȷ2ḅ60

Isso pode ser portado facilmente para 05AB1E, portanto:

05AB1E , 5 bytes

тв60β

Experimente online!

Simplesmente converte o número inteiro de entrada na base 100 e depois converte o resultado da base 60 em número inteiro. Portanto, é equivalente a % de entrada 100 + 60 * Entrada / 100

Mr. Xcoder
fonte
Como função, 5 bytes
caird coinheringaahing 11/11
@cairdcoinheringaahing Eu acho que você quis dizer isso , mas obrigado pelo
alerta
2

Excel VBA, 29 bytes

Função de janela imediata VBE anônima que leva a entrada do intervalo [A1]e sai para a janela imediata VBE.

?[A1]Mod 1E2+60*[Int(A1/100)]
Taylor Scott
fonte
2

APL (Dyalog) , 11 10 bytes

600 100⊤⊢

Experimente online!

Quão?

0 100⊤- codifique na base 100, parando no segundo LSB, produzindo efetivamente n ÷ 100, n % 100.

60⊥ - decodificar na base 60

Uriel
fonte
2

PARI / GP , 16 bytes

Direto:

n->n\100*60+n%100

Infelizmente, esse bom método é simplesmente muito longo para usar:

n->[60,1]*divrem(n,100)
Charles
fonte
2

Pushy , 10 9 bytes

Kevin me superou no meu próprio idioma ... (usando a abordagem da resposta dos ovs )

2dH/40*-#

Experimente online!

10 bytes

sjvj60*^+#

Experimente online!

s             \ Split input into digits
 jvj          \ Join the first two and the last two
    60*       \ Multiply the first by 60
       ^+     \ Add the values
         #    \ Print

11 bytes

Por mais um byte, podemos usar a Input % 100 + 60 * ⌊Input / 100⌋abordagem:

H2d%}/60*+#

Experimente online!

FlipTack
fonte
1
9 bytes criando uma porta da resposta Python 2 do @ovs ' : 2dH/40*-#. Nunca programado em Pushy antes, mas parece uma linguagem bem legal. :)
Kevin Cruijssen
1
@KevinCruijssen é bem uma linguagem baseada em pilha genérico, eu acho que a única coisa um pouco diferente que ela traz para a mesa é a pilha dupla ... mas obrigado, e obrigado pelo golfe :)
FlipTack
1

05AB1E , 9 bytes

т÷60*¹т%+

Experimente online!

Explicação:

т÷60*¹т%+

т         // Push number 100
 ÷        // Integer division with the input
  60      // Push number 60
    *     // Multiply with the previous result
     ¹    // Push input
      т   // Push 100 again
       %  // Modulo
        + // Add the first and the second result

Provavelmente há algum truque com conversões básicas que pode ser alcançado em 05AB1E, mas não consegui encontrá-lo.


fonte
1

bash, 20 bytes

echo $[$1-$1/100*40]

Experimente online

Nahuel Fouilleul
fonte
1

Retina , 11 bytes

.{100}
60$*

Experimente online!

Entrada e saída em unário . O conjunto de testes converte de e para decimal por conveniência.

Fazer esse tipo de conversão de base por apenas dois dígitos é surpreendentemente simples de ser realizado. Apenas combinamos séries de 100 se 1as substituímos por 60 1s. Tudo o que sobrar corresponderia aos dois últimos dígitos na representação decimal e permanecerá inalterado.

Martin Ender
fonte
1

Alice , 19 bytes

/o
\i@/.'d%~'d:'<*+

Experimente online!

Explicação

Pena que eu removi o divmod do idioma, eu acho ...

/o
\i@/...

Essa é apenas a estrutura usual para programas lineares com E / S decimal operando puramente no modo Cardinal (aritmético).

.     Duplicate input.
'd%   Mod 100.
~     Swap with other copy.
'd:   Divide by 100.
'<*   Multiply by 60.
+     Add.
Martin Ender
fonte
1

Via Láctea , 10 bytes

':Z/v40*-!

uso: ./mw code.mwg -i 9999

Explicação:

code       explanation                          stack

'          push input to stack                  [input]
 :         duplicate ToS                        [input, input]
  Z        push 100                             [input, input, 100]
   /v      integer division (divide and floor)  [input, ⌊input/100⌋]
     40    push 40                              [input, ⌊input/100⌋, 40]
       *   multiply                             [input, ⌊input/100⌋*40]
        -  subtract                             [input - ⌊input/100⌋*40]
         ! print
ovs
fonte
1

R , 21 bytes

x=scan();x-x%/%100*40

Experimente online!

Marca
fonte
1
Eu criei minha própria solução em R e era muito menos elegante que isso.
Andrew Brēza
Você pode cortar as scanrespostas, já que a maioria das respostas assume que a variável já está definida.
Andrew Brēza 28/11
As regras são tão inconsistentes com relação a isso. Um dos outros desafios é o de ter uma função ou digitalizar para capturar o valor.
Mark
1

REXX, 25 bytes

arg t
say t%100*60+t//100

(Apenas mais traduções de @ovs)

idrougge
fonte
0

05AB1E , 7 bytes

т‰ć60*+

Experimente online!

Explicação

         command                              current stack
т‰ć60*+  full program. push input implicitly  [1234]
т        push 100                             [1234] [100]
 ‰       push divmod                          [12, 34]
  ć      push head extracted (n[1:], n[0])    [34] [12]
   60*   multiply by 60                       [34] [720]
      +  add and display implicitly           [754]
Cinari
fonte
0

Python simbólico , 66 bytes

___=-~-~_-_
__=___*___
__=__*__*___+___*__
_=_-_/(__+__+__/___)*__

Experimente online!


Explicação

Symbolic Python          values

___=-~-~_-_              ___=2
__=___*___               __=2*2=4
__=__*__*___+___*__      __=4*4*2+2*4=32+8=40
_=_-_/(__+__+__/___)*__  _=_-_/(40+40+40/2)*40=_-_/100*40
ovs
fonte