O que é que este botão faz?

11

Atualmente, no meu trabalho, nos mudamos para um novo prédio. Deveria ser o estado da arte e ter luzes automáticas, persianas automáticas e agora é conhecido como o edifício mais ecológico da cidade.
No entanto, ele realmente não funciona tão bem. Às vezes, as persianas de enrolar se fecham em dias nublados e nasce quando o sol começa a brilhar, e as luzes às vezes causam efeitos de discoteca alternando a ativação e desativação a cada 5-10 minutos. Além disso, não temos nenhuma maneira manual de controlar essas persianas, nem a temperatura, mas temos um controle remoto para as luzes.
Esses controles remotos, no entanto, vieram sem manual de instruções e contêm pouco mais de 20 botões, fazendo todo tipo de coisa, exceto o que você parece querer.

PS: Eu escrevi esse desafio há 1,5 meses na Sandbox. Atualmente, nós meio que sabemos como os controles remotos funcionam.
Uma grande vantagem desse prédio é 30 graus Celsius fora, mas por dentro ele permanece sempre com a mesma temperatura ambiente 21.

Então essa foi a introdução e o controle remoto das luzes inspirou esse desafio.

Desafio:

Digamos que inicialmente tenhamos uma lâmpada desligada:

L

Em seguida, pressionamos todos os tipos de botões e emitimos o estado da lâmpada posteriormente.

Utilizamos os seguintes números para as diferentes funções do controle remoto da lâmpada. Quando um símbolo de menos está na frente desse número, fazemos o oposto.

  • 1= ON; -1= OFF.
  • 2= Aumenta a força em 25%; -2= Diminuir a força (fraca) em 25%.
  • 3= Aumentar spread em 50%; -3= Diminuir o spread em 50%.
  • 4 = Alternando o tipo de luz.

Então, tudo isso é bastante vago, então vamos aprofundar um pouco o que cada coisa significa:

Portanto, -1(OFF) é bastante óbvio e 1irá para o estado ON inicial (50% para 2e 50% para 3):

   //
  //
L ====
  \\
   \\

2e -2é a distância que a luz viaja ( ==é anexada a cada 25%):

0% (equal to a light bulb that is OFF)
L

25%
L ==

50%
L ====

75%
L ======

100%
L ========

3e -3é a que distância a luz se espalha:

0%:
L ====

50%:
   //
  //
L ====
  \\
   \\

100%:
|| //
||//
L ====
||\\
|| \\

(OBSERVAÇÃO: quando 2e 3ambos estiverem em 100%, você terá este estado:

||   //
||  //
|| //
||//
L ========
||\\
|| \\
||  \\
||   \\

4 é alternar o tipo de luz.

Default:
  //
L ==
  \\

After toggling (note the single space before '/' instead of two):
 /
L --
 \

Entrada:

Você receberá uma entrada contendo os possíveis pressionamentos de botão. Por exemplo:

12-34

Resultado:

O estado da lâmpada de luz depois que todos os botões da entrada são pressionados subseqüentemente. Portanto, com a entrada de exemplo acima, temos a seguinte saída:

L ------

Regras do desafio:

  • A entrada contém apenas 1234-(e nunca um -antes do 4).
  • Você nunca pode ficar abaixo de 0% ou acima de 100%. Se um número aumentar / diminuir além desses limites, você poderá ignorá-lo.
  • Quando a lâmpada está desligada, você pode ignorar qualquer ação e, quando ligada novamente, ela volta ao estado ON inicial (50% para ambos 2e 3, e o padrão 4). Por exemplo: 12-1-341apenas imprimirá o estado ON inicial mencionado acima. (DICA: você pode ignorar tudo antes da final 1da entrada - excluindo -1.)
  • Os espaços à direita iguais ao comprimento da luz ou uma única nova linha à direita são desinibidos. Adicionar novas linhas desnecessárias extras não é, no entanto.
  • Você pode receber a entrada como uma lista de números inteiros, em vez de uma única sequência. Então, em vez de 12-34, você pode ter [1,2,-3,4]como entrada.

Regras gerais:

  • Isso é , então a resposta mais curta em bytes vence.
    Não permita que idiomas com código de golfe o desencorajem a postar respostas com idiomas que não sejam codegolf. Tente encontrar uma resposta o mais curta possível para 'qualquer' linguagem de programação.
  • As regras padrão se aplicam à sua resposta, para que você possa usar STDIN / STDOUT, funções / método com os parâmetros adequados, programas completos. Sua chamada.
  • As brechas padrão são proibidas.
  • Se possível, adicione um link com um teste para o seu código.
  • Além disso, adicione uma explicação, se necessário.

Casos de teste:

12-34
L ------

12-1-341
   //
  //
L ====
  \\
   \\

14-3224333-2
||  //
|| //
||//
L ======
||\\
|| \\
||  \\

142-1-314-3-322
L --------

1324-2-3
  /
 /
L ----
 \
  \

134
| /
|/
L ----
|\
| \

1-2-2-214-3-3-3
L ----
Kevin Cruijssen
fonte
1
Para que serve a saída 134?
precisa saber é o seguinte
@ Pietu1998 Adicionei o caso de teste (e consertei algumas coisas relacionadas a espaços após alternar 4). Obrigado por perguntar.
Kevin Cruijssen
1
Não acho que a propagação para o terceiro caso de teste esteja correta.
precisa saber é o seguinte
1
Se a lâmpada estiver acesa e 1pressionada, os parâmetros são redefinidos?
precisa saber é o seguinte
2
Seu escritório é 21º neste clima? Sinto vontade de te derrubar por inveja.
Neil

Respostas:

6

Python 2, 221 bytes

for b in[-1]+input():exec["p=b>0;d=2;s=1;t=2","d+=b/2*(-2<d+b<6)","s+=b/3*(-3<s+b<5)","t=3-t"][abs(b)-1]
i=c=(s>0)*d*p
q='print" |"[s/2]*t+" "*i+t*%r;'
exec('i-=1;'+q%'/')*c
print"L "+" -="[t]*2*d*p
exec(q%'\\'+'i+=1;')*c

Isso acabou sendo mais longo do que eu esperava. A primeira linha calcula o estado da lâmpada, o restante implementa a impressão.

A entrada é fornecida via STDIN no formulário de matriz.

Veja os casos de teste no ideone

PurkkaKoodari
fonte
3

R, 323 320 bytes

    z=scan();a=c=1;b=d=2;for(i in 1:sum(1|z)){s=sign(y<-z[i]);switch(y/s,b<-d<-2*(c<-a<-y),b<-b+s,c<-c+s,d<-2-d);b=min(b,4);c=min(c,2);b=b*(b>0);c=c*(c>0)}
    s="/";v=if(c>1)"|"else" ";for(i in a*b:-b){if(i)cat(v,if(d)v,rep(" ",abs(i)-1),s,if(d)s,"\n",sep="")else{cat("L ",if(d)rep("==",b)else rep("--",b),"\n",sep="");s="\\"}}

Ungolfed:

z=scan()

lê uma linha de entrada (números inteiros separados por espaços)

a=c=1;b=d=2

inicializa as variáveis ​​a (on-ness), b (brilho), c (largura), d (tipo de feixe). dé zero ou dois, o que significa que podemos chamar se (d) mais tarde, em vez de se (d> 1) ou semelhante, e salvar alguns bytes.

while(any(z|1))

Uma maneira de escrever golfe-y, em while(length(z))que z é um vetor inteiro.

O restante da primeira linha lida com a entrada por meio de uma switchinstrução A segunda linha é impressa.

É possível que alguns deles <-possam ser substituídos por =, mas acho que você é comido vivo pelo escopo lexical ...

Observe também que em R, as barras invertidas precisam ser escapadas.

c*(c>0)é uma maneira de escrever max(c,0)que salva um personagem.

Se a luz não estiver acesa, uma vez *que a precedência é inferior a :, o for(i in a*b:-b)loop apenas repete 0:0.

Atualizar; economizou 3 bytes substituindo o loop na primeira linha por um para (em vez de enquanto). Observe que 1:sum(1|z)há menos caracteres que 1:length(z)ou seq_along(z). seq(z)funcionaria na maioria dos casos, mas não quando ztiver comprimento um. A solução apresentada não funcionará para entrada de comprimento zero, mas espero que esteja fora do escopo da competição.

JDL
fonte
2

Kotlin , 445 bytes

Meu primeiro golfe Kotlin, 38 bytes a menos que Java :)

fun f(z:IntArray)={var a=1<0;var b=2;var c=1;var d=a
z.map{when(it){1->{a=1>0;b=2;c=1;d=!a}-1->a=1<0;2->if(b<4)b+=1;-2->if(b>0)b-=1;3->if(c<2)c+=1;-3->if(c>0)c-=1;4->d=!d}}
var r="";val l=if(c>1)if(d)"|" else "||" else if(d)" " else "  "
if(c>0)for(i in b downTo 1)r+="${l+" ".repeat(i-1)+if(d)"/" else "//"}\n"
r+="L ${(if(d)"--" else "==").repeat(b)}\n"
if(c>0)for(i in 1..b)r+=l+" ".repeat(i-1)+"${if(d)"\\" else "\\\\"}\n"
if(a)r else "L"}()

Com espaço em branco e testes:

fun f(z: IntArray) = {
    var a = false // ON / OFF
    var b = 2 // Strength [0,4]
    var c = 1 // Spread [0,2]
    var d = a // Type

    // Find state to print
    z.map {
        when (it) {
            1 -> {
                a = true
                b = 2
                c = 1
                d = !a
            }
            -1 -> a = false
            2 -> if (b < 4) b += 1
            -2 -> if (b > 0) b -= 1
            3 -> if (c < 2) c += 1
            -3 -> if (c > 0) c -= 1
            4 -> d = !d
        }
    }

    var r = ""
    val l = if (c > 1) if (d) "|" else "||"
    else if (d) " " else "  "

    // Print state
    if (c > 0) for (i in b downTo 1) {
        r += "${l + " ".repeat(i - 1) + if (d) "/" else "//"}\n"
    }
    r += "L ${(if (d) "--" else "==").repeat(b)}\n"
    if (c > 0) for (i in 1..b) {
        r += "${l + " ".repeat(i - 1) + if (d) "\\" else "\\\\"}\n"
    }

    /* return */ if (a) r else "L"
}()

fun main(args: Array<String>) {
    println(f(intArrayOf(1, 2, -3, 4)))
    println(f(intArrayOf(1, 2, -1, -3, 4, 1)))
    println(f(intArrayOf(1, 4, -3, 2, 2, 4, 3, 3, 3, -2)))
    println(f(intArrayOf(1, 4, 2, -1, -3, 1, 4, -3, -3, 2, 2)))
    println(f(intArrayOf(1, 3, 2, 4, -2, -3)))
    println(f(intArrayOf(1, 3, 4)))
    println(f(intArrayOf(1, -2, -2, -2, 1, 4, -3, -3, -3)))
}

Curiosamente, em vez de definir a função normalmente e / printou returna string criada, era mais curto usar a atribuição de funções (a fun f() =de um lambda avaliado. (Essa descrição faz sentido?)

Eu só queria que o SE tivesse destaque apropriado da sintaxe de Kotlin

CAD97
fonte
2

Java 8, 484 483 452 446 440 bytes

z->{int a=1,b=2,c=1,d=0,j,k;for(int i:z){d=i==1?0:i>3?1-d:d;a=i*i==1?i:a;b+=i==1?2-b:i==2&b<4?1:i==-2&b>0?-1:0;c+=i==1?1-c:i==3&c<2?1:i==-3&c>0?-1:0;}String t=d<1?"=":"-",q=d<1?"//":"/",x=d<1?"\\\\":"\\",n="\n",y=" ",w=d<1?y+y:y,g=c>1?d<1?"||":"|":w,r="";if(c>0)for(r+=g,j=b;j-->0;r+=q+n+(j>0?c>1?g:w:""))for(k=j;k-->0;r+=y);for(r+="L ",j=b;j-->0;r+=t+t);r+=n;if(c>0)for(r+=g;++j<b;r+=x+n+(j<b-1?g:""))for(k=j;k-->0;r+=y);return a>0?r:"L";}

Finalmente .. Ok, meu próprio desafio é um pouco mais difícil do que eu esperava ..; P

Sem dúvida, isso pode ser jogado de golfe usando uma abordagem completamente diferente. Agora, primeiro determino o que fazer e, em seguida, imprimo-o. A impressão é realmente o mais difícil desse desafio, imho.

-6 bytes graças a @ceilingcat .

Explicação:

Experimente aqui.

z->{                          // Method with integer-array parameter and String return-type
  int a=1,                    //  ON/OFF flag, initially ON
      b=2,                    //  Strength, initially 50%
      c=1,                    //  Spread, initially 50%
      d=0,                    //  Type of light, initially two lines
      j,k;                    //  Index-integers
  for(int i:z){               //  Loop over the input-array
    d=i==1?0:i>3?1-d:d;       //   Determine the new type of light
    a=i*i==1?i:a;             //   Determine if the light is ON/OFF
    b+=i==1?2-b:i==2&b<4?1:i==-2&b>0?-1:0;
                              //   Determine the new strength
    c+=i==1?1-c:i==3&c<2?1:i==-3&c>0?-1:0;}
                              //   Determine the new spread
  String t=d<1?"=":"-",       //  Horizontal light symbol
         q=d<1?"//":"/",      //  Upper diagonal light symbol
         x=d<1?"\\\\":"\\",   //  Bottom diagonal light symbol
         n="\n",              //  New-line
         y=" ",               //  Space
         w=d<1?y+y:y,         //  One or two spaces?
         g=c>1?d<1?"||":"|":w,//  Space(s) or vertical light symbol(s)?
         r="";                //  Result String, starting empty
  if(c>0)                     //  Do we have spread >0%?
    for(r+=g,j=b;j-->0;r+=q+n+(j>0?c>1?g:w:""))for(k=j;k-->0;r+=y);
                              //   Create upper light part
  r+="L ";                    //  Light-bulb
  for(j=b;j-->0;r+=t+t);      //  Horizontal light next to the light-bulb
  r+=n;
  if(c>0)                     //  Do we have spread >0%?
    for(r+=g;++j<b;r+=x+n+(j<b-1?g:""))for(k=j;k-->0;r+=y);
                              //   Create bottom light part
  return a>0?                 //  Is the light turned ON?
             r                //   Return the created result-String
            :                 //  Else:
             "L";}            //   Return just "L"
Kevin Cruijssen
fonte
1

Lote, 552 bytes

@echo off
for %%a in (1 %*) do call:l %%a
set/aw*=o,l*=o
if %w% gtr 0 for /l %%a in (%l%,-1,1)do call:w %%a /
set s=----
if %t%==1 set s=====
call echo L %%s:~-%l%%%%%s:~-%l%%%
if %w% gtr 0 for /l %%a in (1,1,%l%)do call:w %%a \
exit/b
:w
set v= 
set u=%2
if %w%==2 set v=l
if %t%==1 set u=%2%2&set v=%v%%v%
set s=    
call set s=%%s:~-%1%%
echo %v:l=^|%%s:~1%%u%
exit/b
:l
if %1==1 set/ao=w=t=1,l=2
if %1==-1 set/ao=0
if %1==2 set/al+=1-l/4
if %1==-2 set/al-=!!l
if %1==3 set/aw+=1-w/2
if %1==-3 set/aw-=!!w
if %1==4 set/at^=1

Nota: set v=contém um espaço à direita e set s=três. Isso foi realmente estranho, como você não pode imprimir facilmente um número variável de |s no Lote, então você precisa usar um espaço reservado e substituí-lo na instrução echo.

Neil
fonte
0

05AB1E , 106 bytes

“/|= 
L“•Wθ¨S9ƒTª»þúÙ•6вèJ¶¡sŽ8ÃS«1¡θΣÄ}.γÄ}ODd*©н8‚ß8αF樚NÈi¨]R®θ8Öi"||//="2ô…|/-S:}®Ås3/©_iθ}®i'|ð:}».∊

Insira como uma lista de números inteiros.

Experimente online ou verifique todos os casos de teste .

Explicação:

“/|= 
L               # Push string "/|=\nL"
  Wθ¨S9ƒTª»þúÙ• # Push compressed integer 9569494169631511496055972036
   6в            # Converted to Base-6 as list: [5,3,2,2,2,2,2,2,2,2,4,1,1,0,0,4,1,1,3,0,0,4,1,1,3,3,0,0,4,1,1,3,3,3,0,0]
     è           # Index each into the string
      J          # Join everything together

Agora temos a string:

L ========
||//
|| //
||  //
||   //

Então vamos:

¶¡               # Split it by newlines: ["L ========","||//","|| //","||  //","||   //"]
s                # Swap to take the (implicit) input-list
 Ž8Ã             # Push compressed integer 2234
    S            # Converted to a list of digits: [2,2,3,4]
     «           # Append it at the end of the input-list
                 #  i.e. [4,3,3,2,1,3,2,4,-2,-3] → [4,3,3,2,1,3,2,4,-2,-3,2,2,3,4]
 1¡              # Then split on 1
                 #  i.e. [4,3,3,2,1,3,2,4,-2,-3,2,2,3,4]
                 #   → [[4,3,3,2],[3,2,4,-2,-3,2,2,3,4]]
   θ             # Only leave the last inner list
                 #  i.e. [[4,3,3,2],[3,2,4,-2,-3,2,2,3,4]] → [3,2,4,-2,-3,2,2,3,4]
    ΣÄ}          # Sort on the absolute value
                 #  i.e. [3,2,4,-2,-3,2,2,3,4] → [2,-2,2,2,3,-3,3,4,4]
       .γÄ}      # Then group by absolute value
                 #  i.e. [2,-2,2,2,3,-3,3,4,4] → [[2,-2,2,2],[3,-3,3],[4,4]]
           O     # Then take the sum of each group
                 #  i.e. [[2,-2,2,2],[3,-3,3],[4,4]] → [4,3,8]
            Dd   # Duplicate it, and check for each if it's non-negative (>= 0)
                 #  i.e. [4,3,8] → [1,1,1]
              *  # Multiply the two lists
                 #  i.e. [4,3,8] and [1,1,1] → [4,3,8]
               © # And store the result in the register (without popping)
н                # Now take the first value (the strength)
                 #  i.e. [4,3,8] → 4
 8              # Pair it with 8
                 #  i.e. 4 → [4,8]
   ß             # Pop and push the minimum of the two
                 #  i.e. [4,8] → 4
    8α           # And then calculate the absolute difference with 8
                 #  i.e. 4 → 4
      F          # Loop that many times:
       ć         #  Extract the head of the string-list
                 #   i.e. ["L ========","||//","|| //","||  //","||   //"] → "L ========"
        ¨        #  Remove the last character
                 #   i.e. "L ========" → "L ======="
         š       #  And prepend it back to the list again
                 #   i.e. ["||//","|| //","||  //","||   //"] and "L ======="
                 #    → ["L =======","||//","|| //","||  //","||   //"]
       NÈi       #  And if the loop-index is even:
          ¨      #   Also remove the last item of the string-list
                 #    i.e. ["L =======","||//","|| //","||  //","||   //"]
                 #     → ["L =======","||//","|| //","||  //"]
      ]          # Close both the if and loop
                 #  i.e. ["L ========","||//","|| //","||  //","||   //"] and 4
                 #   → ["L ====","||//","|| //"]
       R         # Then reverse the list
                 #  i.e. ["L ====","||//","|| //"] → ["|| //","||//","L ===="]
®                # Push the list from the register again
 θ               # Now take the last value (the toggle)
                 #  i.e. [4,3,8] → 8
  8Öi         }  # If it's divisible by 8:
                 #  i.e. 8 → 1 (truthy)
     "||//="     # Push string "||//="
            2ô   # Split into parts of size 2: ["||","//","="]
     …|/-        # Push string "|/-"
         S       # Split into characters: ["|","/","-"]
     :           # And replace all of them in the string-list
                 #  i.e. ["|| //","||//","L ===="] → ["| /","|/","L ----"]
®                # Push the list from the register again
 Ås              # Now take the middle value (the spread)
                 #  i.e. [4,3,8] → 3
   3/            # Divide it by 3
                 #  i.e. 3 → 1
     ©           # Store it in the register (without popping)
      _i }       # If it's exactly 0:
                 #   i.e. 1 → 0 (falsey)
        θ        #  Only leave the last value of the string-list
     ®i    }     # If it's exactly 1 instead:
                 #   i.e. 1 → 1 (truthy)
       '|ð:     '#  Replace all "|" with spaces " "
                 #   i.e. ["| /","|/","L ----"] → ["  /"," /","L ----"]
»                # Then join the string-list by newlines
                 #  i.e. ["  /"," /","L ----"] → "  /\n /\nL ----"
 .∊              # And finally intersect mirror everything vertically
                 # (which automatically converts the slashes)
                 #  i.e. "  /\n /\nL ----" → "  /\n /\nL ----\n \\n  \"
                 # (And output the result implicitly)

Consulte esta minha dica 05AB1E (seções Como compactar números inteiros grandes? E Como compactar listas de números inteiros? ) Para entender por que •Wθ¨S9ƒTª»þúÙ•6вé [5,3,2,2,2,2,2,2,2,2,4,1,1,0,0,4,1,1,3,0,0,4,1,1,3,3,0,0,4,1,1,3,3,3,0,0]; e Ž8Ãé 2234.

Kevin Cruijssen
fonte