Co robi ten przycisk?

11

Obecnie w mojej pracy przeprowadziliśmy się do nowego budynku. Ma być najnowocześniejszy i ma automatyczne światła, automatyczne rolety, a teraz jest znany jako najbardziej ekologiczny budynek w tym mieście.
Jednak tak naprawdę to nie działa tak dobrze. Rolety opuszczają się czasami w pochmurne dni i wznoszą się, gdy słońce zaczyna świecić, a światła czasami wywołują efekt dyskoteki, naprzemiennie włączając i wyłączając co 5-10 minuty. Ponadto, nie mamy żadnego ręcznego sposobu kontrolowania tych rolet, ani temperatury, ALE mamy pilota do świateł.
Te piloty były jednak dostarczane bez instrukcji obsługi i zawierają niewiele ponad 20 przycisków do robienia różnych rzeczy oprócz tego, czego się wydaje.

PS: Wyzwanie napisałem 1,5 miesiąca temu w piaskownicy. Obecnie wiemy, jak działają piloty.
Jedną wielką zaletą tego budynku jest to, że na zewnątrz jest ponad 30 stopni Celsjusza, ale w środku przez cały czas pozostaje taka sama temperatura pokojowa.

To było wprowadzenie, a pilot do świateł zainspirował to wyzwanie.

Wyzwanie:

Powiedzmy, że początkowo mamy wyłączoną lampę:

L

Następnie wciskamy wszelkiego rodzaju przyciski i następnie wyprowadzamy stan lampy.

Używamy następujących liczb do różnych funkcji pilota do lampy. Kiedy przed tym numerem znajduje się symbol minus, robimy odwrotnie.

  • 1= ON; -1= WYŁ.
  • 2= Zwiększ siłę o 25%; -2= Zmniejsz (przyciemnij) wytrzymałość o 25%.
  • 3= Zwiększ spread o 50%; -3= Zmniejsz spread o 50%.
  • 4 = Przełączanie rodzaju światła.

Wszystko to jest dość niejasne, więc przejdźmy bardziej szczegółowo, co oznacza każda rzecz:

Tak więc -1(WYŁ.) Jest dość oczywiste i 1przejdzie do początkowego stanu WŁĄCZENIA (50% dla 2i 50% dla 3):

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

2i -2określa, jak daleko podróżuje światło ( ==jest dodawane co 25%):

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

25%
L ==

50%
L ====

75%
L ======

100%
L ========

3i -3jak daleko rozprzestrzenia się światło:

0%:
L ====

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

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

(UWAGA: Kiedy 2i 3to zarówno na poziomie 100%, trzeba ten stan:

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

4 jest przełączanie rodzaju światła.

Default:
  //
L ==
  \\

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

Wejście:

Otrzymasz dane wejściowe zawierające możliwe naciśnięcia przycisków. Na przykład:

12-34

Wynik:

Stan lampy świetlnej po naciśnięciu wszystkich przycisków wejścia jest podsekwencyjny. Tak więc z powyższym przykładem przykładowym otrzymujemy następujące dane wyjściowe:

L ------

Zasady konkursu:

  • Dane wejściowe zawierają tylko 1234-(i nigdy -wcześniej 4).
  • Nigdy nie możesz zejść poniżej 0% lub powyżej 100%. Jeśli liczba wzrośnie / spadnie poza te granice, możesz ją zignorować.
  • Gdy lampa jest wyłączona, możesz zignorować wszelkie działania, a po ponownym włączeniu resetuje się z powrotem do początkowego stanu WŁĄCZENIA (50% dla obu 2i 3, i domyślnie 4). Na przykład: 12-1-341wydrukuje tylko wspomniany powyżej początkowy stan włączenia. (WSKAZÓWKA: Możesz zignorować wszystko przed końcem 1danych wejściowych - z wyłączeniem -1.)
  • Końcowe spacje równe długości światła lub pojedynczej nowej linii nie są hamowane. Dodanie dodatkowych niepotrzebnych nowych wierszy nie jest jednak możliwe.
  • Możesz wziąć dane wejściowe jako listę liczb całkowitych zamiast pojedynczego ciągu. Zamiast tego 12-34możesz mieć [1,2,-3,4]jako dane wejściowe.

Główne zasady:

  • To jest , więc wygrywa najkrótsza odpowiedź w bajtach.
    Nie pozwól, aby języki kod-golfowe zniechęcały Cię do publikowania odpowiedzi w językach niekodujących golfa. Spróbuj znaleźć możliwie najkrótszą odpowiedź na „dowolny” język programowania.
  • Do odpowiedzi odnoszą się standardowe reguły , więc możesz używać STDIN / STDOUT, funkcji / metody z odpowiednimi parametrami, pełnych programów. Twoja decyzja.
  • Domyślne luki są zabronione.
  • Jeśli to możliwe, dodaj link z testem swojego kodu.
  • W razie potrzeby dodaj również wyjaśnienie.

Przypadki testowe:

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
źródło
1
Jaka jest wydajność 134?
PurkkaKoodari
@ Pietu1998 Dodałem przypadek testowy (i naprawiłem kilka rzeczy dotyczących spacji po przełączeniu 4). Dzięki, że pytasz.
Kevin Cruijssen
1
Nie sądzę, aby rozkład dla trzeciego przypadku testowego był poprawny.
PurkkaKoodari
1
Jeśli lampa jest włączona i 1naciśnięta, czy parametry są resetowane?
PurkkaKoodari
2
Twoje biuro ma 21º przy tej pogodzie? Mam ochotę oddać ci głos z zazdrości.
Neil

Odpowiedzi:

6

Python 2, 221 bajtów

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

To skończyło się dłużej niż się spodziewałem. Pierwszy wiersz oblicza stan lampy, reszta wdraża drukowanie.

Dane wejściowe są podawane przez STDIN w formie tablicy.

Zobacz przypadki testowe na ideone

PurkkaKoodari
źródło
3

R, 323 320 bajtów

    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="\\"}}

Nie golfowany:

z=scan()

odczytuje linię wejściową (liczby całkowite oddzielone spacjami)

a=c=1;b=d=2

inicjuje zmienne a (on-ness), b (jasność), c (szerokość), d (typ wiązki). dma wartość zero lub dwa, co oznacza, że ​​możemy wywołać if (d) później niż dłużej, jeśli (d> 1) lub podobny i zapisać kilka bajtów.

while(any(z|1))

Golfowy sposób pisania, w while(length(z))którym z jest wektorem całkowitym.

Reszta pierwszego wiersza obsługuje dane wejściowe za pomocą switchinstrukcji. Druga linia zostanie wydrukowana.

Możliwe, że niektóre z nich <-można zastąpić =, ale myślę, że zostajesz zjedzony żywym przez leksykalne określenie zakresu ...

Zauważ również, że w R, odwrotne ukośniki muszą zostać usunięte.

c*(c>0)to golfowy sposób pisania, max(c,0)który ratuje postać.

Jeśli światło nie jest włączone, to ponieważ *ma niższy priorytet niż :, for(i in a*b:-b)pętla tylko się iteruje 0:0.

Aktualizacja; zapisano 3 bajty, zastępując pętlę w pierwszym wierszu znakiem for (zamiast while). Pamiętaj, że 1:sum(1|z)jest mniej znaków niż 1:length(z)lub seq_along(z). seq(z)działałoby w większości przypadków, ale nie, gdy zma długość jeden. Podane rozwiązanie nie będzie działać dla danych wejściowych o długości zero, ale mam nadzieję, że jest to poza zakresem konkursu.

JDL
źródło
2

Kotlin , 445 bajtów

Mój pierwszy golf Kotlin, 38 bajtów mniej niż 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"}()

Z białą przestrzenią i testami:

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

Co ciekawe, zamiast określenia funkcji normalnie i printczy returnutworzony ciąg, było krótsze do przypisania funkcji Użyj ( fun f() =o ocenianym lambda. (Czy to opis ma sens?)

Chciałbym tylko, żeby SE miał właściwe wyróżnianie składni Kotlin

CAD97
źródło
2

Java 8, 484 483 452 446 440 bajtów

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

Wreszcie .. Ok, moje własne wyzwanie jest trochę trudniejsze niż się spodziewałem ..; P

Można to bez wątpienia pograć w golfa, stosując zupełnie inne podejście. Teraz najpierw określam, co robić, a następnie drukuję. Druk jest w rzeczywistości najtrudniejszy z tego wyzwania, imho.

-6 bajtów dzięki @ceilingcat .

Wyjaśnienie:

Wypróbuj tutaj.

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
źródło
1

Partia, 552 bajtów

@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

Uwaga: set v=zawiera jedno końcowe miejsce i set s=zawiera trzy. To było naprawdę niezręczne, ponieważ nie można łatwo wydrukować zmiennej liczby |wsadowej w partii, więc musisz użyć symbolu zastępczego i zastąpić go w instrukcji echo.

Neil
źródło
0

05AB1E , 106 bajtów

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

Wprowadź jako listę liczb całkowitych.

Wypróbuj online lub sprawdź wszystkie przypadki testowe .

Wyjaśnienie:

“/|= 
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

Mamy teraz ciąg:

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

Następnie będziemy:

¶¡               # 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)

Zobacz ten 05AB1E końcówki kopalni (sekcje Jak skompresować dużych liczb całkowitych? I jak skompresować list całkowitych? ) , Aby zrozumieć, dlaczego •Wθ¨S9ƒTª»þúÙ•6вjest [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]; i Ž8Ãjest 2234.

Kevin Cruijssen
źródło