Что делает эта кнопка?

11

В настоящее время на моей работе мы переехали в новое здание. Предполагается, что он является самым современным и имеет автоматическое освещение, автоматические жалюзи, и теперь известен как самое экологичное здание в этом городе.
Тем не менее, это не очень хорошо работает. Роллеты иногда закрываются в пасмурные дни и поднимаются, когда солнце начинает светить, а огни иногда вызывают диско-эффекты, чередуя включение и выключение каждые 5-10 минут. Кроме того, у нас нет никакого ручного способа управления этими жалюзи, ни температуры, НО у нас есть пульт для освещения.
Эти пульты, тем не менее, поставляются без инструкции по эксплуатации и содержат чуть более 20 кнопок, выполняющих все виды задач, за исключением того, что вы, кажется, хотите.

PS: я написал этот вызов 1,5 месяца назад в Песочнице. В настоящее время мы, вроде как, знаем, как работают пульты дистанционного управления.
Одно большое преимущество этого здания - снаружи 30 градусов Цельсия, но внутри него всегда остается одна и та же температура в помещении.

Итак, это было вступление, и пульт управления светом вдохновил этот вызов.

Вызов:

Допустим, у нас изначально выключена лампа:

L

Затем мы нажимаем все виды кнопок и затем выводим состояние лампы.

Мы используем следующие цифры для различных функций пульта дистанционного управления для лампы. Когда знак минус перед этим числом, мы делаем наоборот.

  • 1= ВКЛ; -1= ВЫКЛ.
  • 2= Увеличить силу на 25%; -2= Уменьшение (уменьшение) силы на 25%.
  • 3= Увеличить спред на 50%; -3= Уменьшить спред на 50%.
  • 4 = Переключение типа света.

Итак, все это довольно расплывчато, поэтому давайте немного углубимся в то, что означает каждая вещь:

Итак, -1(ВЫКЛ) довольно очевидно, и 1перейдет в исходное состояние ВКЛ (50% для 2и 50% для 3):

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

2и -2как далеко проходит свет ( ==добавляется на каждые 25%):

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

25%
L ==

50%
L ====

75%
L ======

100%
L ========

3и -3как далеко распространяется свет:

0%:
L ====

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

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

(ПРИМЕЧАНИЕ: когда 2и 3оба на 100%, у вас будет это состояние:

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

4 это переключить тип света.

Default:
  //
L ==
  \\

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

Входные данные:

Вы получите ввод, содержащий возможные нажатия кнопок. Например:

12-34

Выход:

Состояние световой лампы после последовательного нажатия всех кнопок входа. Итак, с приведенным выше примером ввода мы имеем следующий вывод:

L ------

Правила вызова:

  • Вход содержит только 1234-(и никогда не -до 4).
  • Вы никогда не можете опуститься ниже 0% или выше 100%. Если число будет увеличиваться / уменьшаться за пределами этих границ, вы можете игнорировать его.
  • Когда лампа выключена, вы можете игнорировать любые действия, а при повторном включении она возвращается в исходное состояние ВКЛ (50% для обоих 2и 3, и по умолчанию 4). Например: 12-1-341просто распечатает начальное состояние ВКЛ, упомянутое выше. (СОВЕТ: Вы можете игнорировать все до 1окончания ввода - исключая -1.)
  • Замыкающие пробелы, равные длине света или одной новой конечной линии, запрещены. Добавление дополнительных ненужных новых строк, однако, не так.
  • Вам разрешено принимать входные данные в виде списка целых чисел вместо одной строки. Таким образом, вместо 12-34, вы можете иметь в [1,2,-3,4]качестве входных данных.

Основные правила:

  • Это , поэтому выигрывает самый короткий ответ в байтах.
    Не позволяйте языкам кода-гольфа отговаривать вас от публикации ответов на языках, не относящихся к кодексу. Попробуйте найти как можно более короткий ответ для «любого» языка программирования.
  • К вашему ответу применяются стандартные правила , поэтому вы можете использовать STDIN / STDOUT, функции / метод с соответствующими параметрами, полные программы. Ваш звонок.
  • По умолчанию лазейки запрещены.
  • Если возможно, добавьте ссылку с тестом для вашего кода.
  • Также, пожалуйста, добавьте объяснение, если это необходимо.

Тестовые случаи:

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 ----
Кевин Круйссен
источник
1
Для чего нужен выход 134?
PurkkaKoodari
@ Pietu1998 Я добавил тестовый пример (и исправил некоторые вещи, касающиеся пробелов после переключения 4). Спасибо за вопрос.
Кевин Круйссен
1
Я не думаю, что спред для третьего контрольного примера правильный.
PurkkaKoodari
1
Если лампа включена и 1нажата, параметры сбрасываются?
PurkkaKoodari
2
Ваш офис 21 ° в такую ​​погоду? Я чувствую, что подавляю тебя из зависти.
Нил

Ответы:

6

Python 2, 221 байт

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

Это оказалось дольше, чем я ожидал. Первая строка рассчитывает состояние лампы, остальные осуществляют печать.

Ввод осуществляется через STDIN в виде массива.

Смотрите тестовые случаи на ideone

PurkkaKoodari
источник
3

R 323 320 байт

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

читает строку ввода (целые числа разделены пробелами)

a=c=1;b=d=2

инициализирует переменные a (on-ness), b (яркость), c (ширина), d (тип луча). dэто либо ноль, либо два, что означает, что мы можем вызвать if (d) позже, а не long, если (d> 1) или аналогичный, и сохранить пару байтов.

while(any(z|1))

Golf-y способ записи, while(length(z))где z - целочисленный вектор.

Остальная часть первой строки обрабатывает ввод с помощью switchоператора. Вторая строка распечатывается.

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

Также обратите внимание, что в R обратные слеши должны быть экранированы.

c*(c>0)это гольф-способ письма, max(c,0)который сохраняет характер.

Если индикатор не горит, то , так как *имеет более низкий приоритет , чем :, то for(i in a*b:-b)цикл только перебирает 0:0.

Обновить; сохранил 3 байта, заменив цикл в первой строке символом for (а не while). Обратите внимание, что 1:sum(1|z)символов меньше, чем 1:length(z)или seq_along(z). seq(z)будет работать в большинстве случаев, но не тогда, когда он zимеет длину один. Данное решение не будет работать для ввода нулевой длины, но я надеюсь, что это выходит за рамки конкуренции.

JDL
источник
2

Котлин , 445 байт

Мой первый Kotlin Golf, на 38 байт меньше, чем 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"}()

С пробелами и тестами:

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

Интересно, что вместо того, чтобы определять функцию как обычно и / printили returnсозданную строку, было короче использовать назначение функции ( fun f() =оцененной лямбды. (Имеет ли это описание смысл?)

Я просто хотел бы, чтобы у SE была правильная подсветка синтаксиса Kotlin

CAD97
источник
2

Java 8, 484 483 452 446 440 байт

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

Наконец-то .. Хорошо, мой собственный вызов немного сложнее, чем я ожидал ..; P

Без сомнения, это можно сделать, используя совершенно другой подход. Теперь я сначала определяю, что делать, а затем распечатываю. Печать на самом деле самая сложная в этом, имхо.

-6 байт благодаря @ceilingcat .

Объяснение:

Попробуй это здесь.

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"
Кевин Круйссен
источник
1

Пакетная, 552 байта

@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

Примечание: set v=содержит один завершающий пробел и set s=содержит три. Это было очень неудобно, так как вы не можете легко напечатать переменное число |s в Batch, поэтому вы должны использовать заполнитель и заменить его в выражении echo.

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

05AB1E , 106 байт

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

Ввод в виде списка целых чисел.

Попробуйте онлайн или проверьте все контрольные примеры .

Объяснение:

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

Теперь у нас есть строка:

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

Тогда мы будем:

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

Смотрите этот 05AB1E наконечника шахты (разделы Как сжать большие целые числа? И Как сжать целые списки? ) , Чтобы понять , почему •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]; и Ž8Ãесть 2234.

Кевин Круйссен
источник