Сколько времени в юникоде?


12

Задача проста, учитывая время ввода в виде строки в любом из следующих форматов:

hh, hh:mmИли hh:mm:ssс 0 ≤ hh ≤ 23, 0 ≤ mm ≤ 59и 0 ≤ ss ≤ 59.

Выведите, в какое время он использует следующие символы:

AA  LABEL FOR CHARACTER     CODE POINT   HEXADECIMAL
==  ====================    ==========   ===========
🕐  Clock Face 01 Oclock    128336       0x1F550  
🕑  Clock Face 02 Oclock    128337       0x1F551  
🕒  Clock Face 03 Oclock    128338       0x1F552  
🕓  Clock Face 04 Oclock    128339       0x1F553  
🕔  Clock Face 05 Oclock    128340       0x1F554  
🕕  Clock Face 06 Oclock    128341       0x1F555  
🕖  Clock Face 07 Oclock    128342       0x1F556  
🕗  Clock Face 08 Oclock    128343       0x1F557  
🕘  Clock Face 09 Oclock    128344       0x1F558  
🕙  Clock Face 10 Oclock    128345       0x1F559  
🕚  Clock Face 11 Oclock    128346       0x1F55A  
🕛  Clock Face 12 Oclock    128347       0x1F55B  

В следующем формате:

It is currently {Clock Face 1} with {mm} minutes and {ss} seconds until {Clock Face 2}.

Примеры (включая все дополнительные случаи):

Дело только с часами ...

f("12") = "It is currently 🕛."

Дело с часами и минутами ...

f("12:30") = "It is currently 🕛 with 30 minutes until 🕐."

Дело только с часами, но включает минуты как 00 ...

f("12:00") = "It is currently 🕛."

Случай с часами, минутами и секундами ...

f("12:30:30") = "It is currently 🕛 with 29 minutes and 30 seconds until 🕐."

Случай с часами и минутами, но с включенными секундами как 00 ...

f("12:30:00") = "It is currently 🕛 with 30 minutes until 🕐."

Случай с часами и минутами, менее чем за минуту до следующего часа ...

f("12:59:59") = "It is currently 🕛 with 1 seconds until 🕐."

Вам не нужно переходить от множественного числа к единственному.


Случай с часами и минутами, с 1 минуты до следующего часа ...

f("12:59") = "It is currently 🕛 with 1 minutes until 🕐."

Вам не нужно переходить от множественного числа к единственному.


Случай использования военного времени (да, вы должны справиться с этим) ...

f("23:30:30") = "It is currently 🕚 with 29 minutes and 30 seconds until 🕛."

Неверные случаи ...

f("PPCG") = This cannot occur, you are guaranteed a valid format by the definition of the problem.
f(66:66:66) = This cannot occur, you are guaranteed valid numbers by the definition of the problem.
f(24:60:60) = This cannot occur, you are guaranteed valid numbers by the definition of the problem.

Вы не должны соответствовать какой-либо стиль вывода для недопустимых случаев, ошибки в порядке.


В целом, задача довольно проста, но, на мой взгляд, кажется достаточно динамичной, чтобы быть веселой. Самый короткий код здесь - победитель, так как в коде не так много переменных, кроме длины.



Это целая программа или достаточно функции / лямбды?
devRicher

2
Я думаю, что вместо 0 < hh < 24, 0 < mm < 60и 0 < ss < 60, вы имели в виду 0 ≤ hh ≤ 23, 0 ≤ mm ≤ 59и 0 ≤ ss ≤ 59.
Эрик Outgolfer

2
Разрешена ли в качестве входных данных структура Date / DateTime для конкретного языка?
devRicher

2
@carcusocomputing Вы указываете, что код должен обрабатывать 24 часа, код должен обрабатывать AMили PMтеги?
Тейлор Скотт

Ответы:


3

Befunge, 256 250 байт

>&~85+`v
8~-&"<"_00v`+5
0v%\-&"<<"_
v>:00p!!-"<"%10p65++:66+%0" yltnerruc si tI">:#,_$"Hu 5x"2*,3*,+,2*+,10g00g+
_".",@,".",+*2,+,*3,*2"x5 uH"%+66+1$_,#!>#:<v0
" litnu  htiw ",,,,,,10g:>#v_$"sdnoces"00g.^>
_>,,,,,,,>" dna ">,,,,,00^ >."setunim"00g!#^

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

Результаты кодируются как utf-8, так как это лучше всего работает с TIO, но если вы проводите локальное тестирование, вам может потребоваться настроить кодовую страницу по умолчанию для вашей системы, чтобы правильно видеть циферблаты. В противном случае просто перенаправьте вывод в файл и откройте его в редакторе, совместимом с utf-8.

объяснение

Первые три строки читают часы, минуты и секунды из стандартного ввода, проверяя EOF или перевод строки после каждого значения и подставляя нули для компонентов, отсутствующих во входных данных. В четвертой строке мы корректируем значение минуты, если секунды отличны от нуля, переводим значение часа в диапазон от 0 до 11 (чтобы соответствовать соответствующему символу Юникода для каждого часа) и записываем начальную часть вывода, включая первый циферблат.

Именно в этот момент нам нужно следовать различным ветвям в зависимости от того, какие компоненты отличны от нуля. Первый тест в начале пятой строки просто проверяет, равны ли минуты и секунды нулю. Если это так, мы выписываем финал .и выход. В противном случае строки шесть и семь имеют дело с оставшимися случаями - выписывают соответствующий текст и значения, прежде чем все пути снова объединяются в строке пять, чтобы выписать конечный циферблат (выполнение справа налево).


3

JavaScript (ES6), 201

t=>(T=h=>String.fromCodePoint(128336+h%12),[h,m,s]=t.match(/\d+/g),'It is currently '+T(h-=~10)+((m-=-!!-s)?` with ${60-m?60-m+' minutes'+(-s?' and ':''):''}${-s?60-s+' seconds':''} until `+T(-~h):''))

Меньше гольфа

t=>(
  T=h=>String.fromCodePoint(128336+h%12),
  [h,m,s]=t.match(/\d+/g),
  'It is currently '+T(h-=~10)
   +( 
      // if seconds is not 0, increment m else just convert to number
      // have to use '- -' to force conversion to number 
     (m -= - !!-s) 
-s?++m:m)
      ? ` with ${60-m ? 60-m+' minutes'+(-s?' and ':''):''}${-s?60-s+' seconds':''} until `+T(-~h)
      : ''
    )
)

Тестовое задание

F=
t=>(T=h=>String.fromCodePoint(128336+h%12),[h,m,s]=t.match(/\d+/g),'It is currently '+T(h-=~10)+((m-=-!!-s)?` with ${60-m?60-m+' minutes'+(-s?' and ':''):''}${-s?60-s+' seconds':''} until `+T(-~h):'')
)


var tid=0

function getTime(t)
{
  var a=t.match(/\d+/g)
  if (a) {
    var [h,m,s]=a
    h|=0, s|=0, m|=0
    if(h>=0 & h<24 & m>=0 & m<60 & s>=0 & s<60) 
      return [h,m,s]
  }
  return null
}      

function update()
{
  clearTimeout(tid)
  var t=I.value, a=getTime(t)
  if (a) {
    O.textContent = F(t)
    tid = setTimeout(again,5000)
  }
  else {
    O.textContent = 'invalid ' + t
  }
}
function again()
{      
  var t=I.value, a=getTime(t)
  if (a) {
    var [h,m,s]=a
    ++s>59?(s=0,++m>59?(m=0,++h):0):0
    h%=24
    s<10?s='0'+s:0
    m<10?m='0'+m:0
    t = h+(-m-s?':'+m+(-s?':'+s:''):'')
    I.value = t
    O.textContent=F(t)
    tid = setTimeout(again, 1000)
  }
}

update()
#O { font-size:16px }
Time <input id=I value='12' oninput='update()' onkeydown='update()'>
(modify current time as you wish - but use valid values)
<pre id=O></pre>


Я не знаю, как выбрать победителя для этого, вы оба разместили в течение 2 минут друг друга с 201 байтом на одном языке.
Волшебная Урна Осьминога

@carusocomputing, конечно, вы должны выбрать меня. Мне. МЕНЯ МЕНЯ МЕНЯ! ...
edc65

@carusocomputing, иначе вы можете выбрать ответ, у которого меньше голосов (без причины), просто чтобы восстановить баланс
edc65

Или вы можете заменить слово Stringв вашем коде ""пустой строкой, чтобы сэкономить 4 байта :). Ах, дерьмо, он тоже может.
Волшебная Урна Осьминога

Показывает It is currently 🕛 with 60 minutes until 🕐. Я думаю, что долженIt is currently 🕛.
Роман Gräf

2

JavaScript (ES6), 201 байт

(i,[h,m,s]=i.split`:`,c=n=>String.fromCodePoint(128336+(n+11)%12))=>`It is currently ${c(+h)}${m|s?` with ${(m=59+!+s-m)?m+` minutes`:``}${+s&&m?` and `:``}${+s?60-s+` seconds`:``} until `+c(-~h):``}.`

226 байт, если принять во внимание множественное число:

f=
(i,[h,m,s]=i.split`:`,c=n=>String.fromCodePoint(128336+(n+11)%12))=>`It is currently ${c(+h)}${m|s?` with ${(m=59+!+s-m)?m+` minute`+(m-1?`s`:``):``}${+s&&m?` and `:``}${+s?60-s+` second`+(59-s?`s`:``):``} until `+c(-~h):``}.`
<input oninput=o.textContent=f(this.value)><div id=o>



1

C 241 байт

Записывает UTF-8 в стандартный вывод.

#define p printf(
c(v,h){p"%s \xf0\x9f\x95%c",v,144+h%12);}f(t){int h=0,m=0,s=0;sscanf(t,"%d:%d:%d",&h,&m,&s);m=(59-m+!s)%60;c("It is currently",h-1);m&&p" with %d minutes",m);s&&p" %s %d seconds",m?"and":"with",60-s);m|s&&c(" to",h);p".");}

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

Код с пробелами:

#define p printf(

c(v, h) {
    p"%s \xf0\x9f\x95%c", v, 144 + h % 12);
}

f(t) {
    int h = 0, m = 0, s = 0;

    sscanf(t, "%d:%d:%d", &h, &m, &s);
    c("It is currently", h - 1);
    m = (59 - m + !s) % 60;
    m && p" with %d minutes", m);
    s && p" %s %d seconds", m ? "and" : "with", 60 - s);
    m | s && c(" to", h);
    p".");
}
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.