Нарисуйте звездочку аналоговые часы для часа N


22

Вызов:

Создайте функцию или программу, которая будет принимать вход N (число от 0 до 24), который представляет ЧАС.

На выходе должны быть нарисованы аналоговые часы из звездочек, показывающие час N.

🕛🕐🕑🕒🕓🕔🕕🕖🕗🕘🕙🕚🕛🕐🕑🕒🕓🕔🕕🕖🕗🕘🕙🕚🕛


Заметки:

• Минутная стрелка должна быть длиннее часовой (с точки зрения количества используемых звездочек)

• Минутная стрелка должна содержать не менее 2 звездочек.

• Полдень, 3 часа дня, 6 часов вечера и 9 часов вечера всегда будут ортогональны. Ваши выходные данные за промежуточные часы, если они расположены в градусах, должны быть в том же порядке, что и часы дня. То , что я имею в виду, в полдень час рука 0º и в 3 часа часовая стрелка 90º так для выходных случаев 1pm и 2PM следующее должно быть истинным: 0pm_deg < 1pm_deg < 2pm_deg < 3pm_deg. Помимо этого правила фактическое количество степеней может быть любым, что вы решите, очевидно, оно будет меняться в зависимости от шрифта и других собственных факторов.

• Соединительное соединение между часовой стрелкой и минутной стрелкой является круглым / овальным символом юникода любого типа. o, O, •, 0, etc.


Пример ввода / вывода (может варьироваться в зависимости от стиля рисования)

 N = 3;

 *
 *
 *
 O  *  *

 N = 4;

 *
 *
 *
 O
    *
       *

 N = 5;

 *
 *
 *
 0
  *
   *

 N = 6;

 *
 *
 o
 *

 N = 7;

      *
      *
      *
      •
    *
  *

 N = 0,12,24;

 *
 *
 *
 o

Пример дифференциации выходов:

 N = 4     VS     N = 5     VS     N = 6

  *                *                *
  *                *                *
  O                O                O
      *              *              *

Это , поэтому выигрывает программа с самым коротким байтом!


8
Часы обычно от 0 до 23 или от 1 до 12, а не от 0 до 24, если у вас нет 25 часов в день
fɪnɛt'k

1
Минутная стрелка должна быть длиннее часовой, но нужно ли им сохранять свои размеры? Например, может ли минутная стрелка 3иметь размер, отличный от минутной 7?
AdmBorkBork

@LliwTelracs но 23:00есть 11:00. На мой взгляд, я снова пытался вернуться к 12
Альберт Реншоу,

6
@LliwTelracs В некоторые дни точно чувствую, что они делают!

1
Принимаются ли ведущие или конечные пробелы / переводы строк? Как насчет заполнения?
Тит

Ответы:


18

Javascript (ES6), 105 76 65 байт

F=N=>`  *
ab*12
 9@3
87654`.replace(/\w/g,y=>'0x'+y^N%12?' ':'*')
<!-- Snippet Demo: -->
N =  <input type="number" min="0" max="24" value="2" id="I" />
<button onclick="console.log(F(I.value))">Run</button>

  • -29 байт:

    • Уменьшен размер минутной и часовой стрелки до 2 и 1 звездочки соответственно. Меньшие часы = меньше байтов :-P
  • -11 байт:

    • Изменено сравнение строк на числовое сравнение.
    • y==(N%12).toString(16)?'*':' ' -> '0x'+y^N%12?' ':'*'

Оригинал с более длинными руками: ( 105 94 байта)

F=N=>`    *
a b * 1 2
  ab*12
  99@33
  87654
8 7 6 5 4`.replace(/\w/g,y=>'0x'+y^N%12?' ':'*')
<!-- Snippet Demo: -->
N =  <input type="number" min="0" max="24" value="2" id="I" />
<button onclick="console.log(F(I.value))">Run</button>


1
Это действительно умно!
AdmBorkBork

1
Ух ты, мне это очень нравится!
Альберт Реншоу

К сожалению. Мой ответ на Python немного похож на ваш оригинал. Я отвечал раньше, чем увидел твой ответ, если честно. Думаю, у нас была та же идея с гексом.
ElPedro

2
и я как-то читаю его как «Часовая стрелка должна быть как минимум 2 ...», так что +1 для правильного чтения и сокращения стрелок.
ElPedro

1
@ElPedro, это то, что я думал, что я тоже читал изначально :)
nderscore

14

CSS / HTML (JavaScript), 62 + 106 = 180 168 байт

pre{position:absolute;left:99px;bottom:99px;transform-origin:50% 80%}
<input oninput=h.style.transform=`rotate(${this.value*30}deg)`><pre>*
*
o</pre><pre id=h>*

</pre>

Изменить: Сохранено 9 байтов благодаря @nderscore.


Очень классная идея!
nderscore

Действительно хороший ответ.
ElPedro

Вы можете сбрить 4 байта с вашего входного тега, поменяв его местами с этим<body onload=f(prompt())>
Альберт Реншоу

1
Вы также можете напрямую встроить код функции в атрибут oninput:<input oninput=h.style.transform=`rotate(${this.value*30}deg)`>
nderscore

9

Python 2 , 148 140 135 байтов

-8, удалив оставшиеся пробелы и ненужный перевод строки.

-5, изменив (' ','*')на' *'

a=input()
b='''    *
a b * 1 2
  ab*12
9 9 o 3 3
  87654
8 7 6 5 4'''
for x in range(1,12):b=b.replace(hex(x)[2],' *'[x==a%12])
print b

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


5

C (gcc) , 144 байта

#define v ,t
h;t(i){putchar(i>12?i-9:h^i?32:42);}n(i){h=i%12;puts("  *")v(10)v(11)v(h)v(1)v(2)v(19)v(12)v(9)v(57)v(3)v(19)v(8)v(7)v(6)v(5)v(4);}

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


+1; Святая рекурсия! Я нахожу забавным то, что вы можете сэкономить байты в коде-гольфе, используя макрос с запятой ахха
Альберт Реншоу

Я тоже этого не ожидал, хотя в поле зрения нет рекурсии. Это жестко закодированный ответ, хотя и слегка запутанный.
Ahemone

Я не думаю, что вам нужно место перед запятой
потолок кошка

4

SmileBASIC, 90 88 74 байта

INPUT H?("  *"+" "*47)*2;"  o
R=H/1.9LOCATE 2.5+SIN(R)*2,3.5-COS(R)*2?"*

Пример вывода:

? 5
  *
  *
  o

   *

? 3
  *
  *
  o *


3

Желе , 35 34 33 байта

ị“ tI©’Œ?Ḋ¤µ⁶ẋ13”*⁸¦Ṗ;“**o”ṙ7s5ZY

Попробуйте онлайн! (tI©!) или просмотреть все (0 - 24) .

Как?

ị“ tI©’Œ?Ḋ¤µ⁶ẋ13”*⁸¦Ṗ;“**o”ṙ7s5ZY - Main link: h
          ¤                       - nilad followed by link(s) as a nilad:
 “ tI©’                           -     base 250 number: 522956007
       Œ?                         - shortest permutation of [1,N] that would be at
                                     that index in a lexicographically sorted
                                     list: [2,3,4,5,6,7,1,12,11,10,9,8,13]
         Ḋ                        - dequeue: [3,4,5,6,7,1,12,11,10,9,8,13]
ị                                 - index into (1-based and modular, so h=2 picks 4,
                                     as does h=14 [as do h=26, h=-10, etc.])
           µ                      - monadic chain separation (call the result j)
            ⁶                     - space character
             ẋ13                  - repeat 13 times
                   ¦              - apply to index...
                  ⁸               - ...left argument (j)
                ”*                -     an asterisk character (replacemes the space
                                         at index j with an asterisk)
                    Ṗ             - pop the last character off the list †
                     ;“**o”       - concatenate "**o"
                           ṙ7     - rotate left by 7 ‡
                             s5   - split into chunks of length 5 (columns)
                               Z  - transpose (get the rows of the clock)
                                Y - join with line feeds
                                  - implicit print

Обратите внимание, что “ tI©’Œ?Ḋ(перестановка в индексе, исключение из очереди) - это сохранение байтов “9ȧỤ_ÑḶ’b⁴(база 16 из), то есть сохранение байтов “¦þxṙ<ȥ’ḃ13(биективная база 13 из).

Что касается всплывающего окна - у нас есть дополнительный пробел в строке, куда звездочка для 0, 12, 24 пойдет, чтобы позволить индексирование mod-12 списка индексов, выталкивание последнего символа там на байты дешевле, чем делать конкатенацию “**o”заранее и перезаписать одну из этих звездочек.

Что касается поворота - это байтовое сохранение по сравнению с построением строки с `« ** o »в середине (либо с ней до, либо после размещения звездочки).


3

Haskell, 148 байт

c n=mapM_ putStrLn$(t(n-3)!(t n!(\_->'*')))(map(\x->(2!(\_->x))"     ")"**O  ")
n!f=(\(x,a:y)->x++f a:y).splitAt n
t n=2+truncate(2.5*sin(n*pi/6))

Функция с является той, которая решает данную задачу



2

PHP, 71 байт

1 звездочка часовая стрелка, 2 звездочки минутная стрелка.

$s="  *
  *  
  O  
";$s[ord(BGHNTSRQPJDE[$argv[1]%12])&31]="*";echo$s;

принимает входные данные из аргумента командной строки; беги с -nr.

  1. определить шаблон
  2. сопоставить час с позицией (декодировать с буквы) и установить символ в позиции на звездочку
  3. Распечатать

1

05AB1E , 41 байт

Это слишком медленно для TIO.

14Ýœ•2!&ô÷‰•èv… *@y_2L11+¹12%0‚ìyå+èJ}3ô»

Для аналогичного кода, работающего на TIO попробуйте это

Уверен, что это все еще может быть как игра в гольф, так и ускорение.
Объяснение будет позже.


1

Logicode 634 байта

Не могу понять, как вводить, поэтому есть переменная a = ... для ввода вверху ссылки tio

circ v(a)->cond((a&1000)+0)&a->0/a
circ n(a)->cond a&10000->((a&100)+0)|!(a&100)&((a&011)|100)/a
circ y(a)->cond((a&100)+0)&a->a&10011/a
var s=@100000
var m=@101010
var x=y(n(v(a)))
var e=x&1000
var f=(x&100)+0
var t=(x&10)+00
var o=(x&1)+000
circ r(a,b)->cond(a)->b/@a
out s+s+s+s+m
out r(e&t&!o,m)+s+r(o&e&t,m)+s+m+s+r(o&!e&!f&!t,m)+s+r(t&!o&!f&!e,m)
out s+s+r(e&t&!o,m)+r(e&t&o,m)+m+r(o&!t&!f&!e,m)+r(t&!o&!f&!e,m)
out r(e&o&!t,m)+s+r(e&o&!t,m)+s+@110000+s+r(t&o&!f&!e,m)+s+r(t&o&!f&!e,m)
out s+s+r(e&!t&!o,m)+r((f&t&o),m)+r(f&t&!o,m)+r(f&!t&o,m)+r(f&!t&!o,m)
out r(e&!t&!o,m)+s+r(f&t&o,m)+s+r(f&t&!o,m)+s+r(f&o&!t,m)+s+r(f&!t&!o,m)

Отказались от игры в гольф. Может сделать его короче за счет того, что часы выглядят ужасно.

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

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.