Która jest godzina w Unicode?

12

Wyzwanie jest uproszczone, biorąc pod uwagę czas wprowadzania jako ciąg znaków w jednym z następujących formatów:

hh, hh:mmLub hh:mm:ssz 0 ≤ hh ≤ 23, 0 ≤ mm ≤ 59a 0 ≤ ss ≤ 59.

Podaj, która godzina jest obecnie, używając następujących symboli:

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  

W następującym formacie:

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

Przykłady (w tym wszystkie przypadki z marginesami):

Sprawa z tylko godzinami ...

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

Skrzynia z godzinami i minutami ...

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

Sprawa z godzinami, ale minuty są wliczone jako 00 ...

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

Sprawa z godzinami, minutami i sekundami ...

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

Sprawa z godzinami i minutami, ale ma sekundy uwzględnione jako 00 ...

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

Sprawa z godzinami i minutami, z mniej niż minutą do następnej godziny ...

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

Nie musisz zmieniać z liczby mnogiej na liczbę pojedynczą.


Sprawa z godzinami i minutami, z 1 minutą do następnej godziny ...

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

Nie musisz zmieniać z liczby mnogiej na liczbę pojedynczą.


Sprawa wykorzystująca czas wojskowy (tak, musisz sobie z tym poradzić) ...

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

Nieprawidłowe przypadki ...

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.

W przypadku niepoprawnych przypadków nie trzeba dostosowywać się do żadnego stylu, błędy są w porządku.


Ogólnie wyzwanie jest dość uproszczone, ale wydaje się być wystarczająco dynamiczne, aby moim zdaniem było zabawne. Najkrótszy kod tutaj jest zwycięzcą, ponieważ nie ma wiele zmiennych aspektów w kodzie oprócz długości.

Urna Magicznej Ośmiornicy
źródło
1
Blisko związane.
Martin Ender,
Czy powinien to być cały program, czy wystarczy funkcja / lambda?
devRicher
2
Myślę, że zamiast 0 < hh < 24, 0 < mm < 60i 0 < ss < 60, masz na myśli 0 ≤ hh ≤ 23, 0 ≤ mm ≤ 59i 0 ≤ ss ≤ 59.
Erik the Outgolfer,
2
Czy struktura Data / DateTime specyficzna dla języka jest dozwolona jako dane wejściowe?
devRicher
2
@carcusocomputing Podajesz, że kod musi obsługiwać 24 godziny, czy kod musi obsługiwać AMczy PMtagi?
Taylor Scott

Odpowiedzi:

3

Befunge, 256 250 bajtów

>&~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!#^

Wypróbuj online!

Wyniki są zakodowane jako utf-8, ponieważ działa najlepiej z TIO, ale jeśli testujesz lokalnie, może być konieczne dostosowanie domyślnej strony kodowej systemu, aby poprawnie wyświetlać tarcze zegara. W przeciwnym razie wystarczy przekierować wyjście do pliku i otworzyć go w edytorze kompatybilnym z utf-8.

Wyjaśnienie

Pierwsze trzy wiersze odczytują godziny, minuty i sekundy od wejścia standardowego, sprawdzając EOF lub wysuw wiersza po każdej wartości i zastępując zerem brakujące elementy wejściowe. W wierszu czwartym dostosowujemy wartość minut, jeśli sekundy są niezerowe, przekształcamy wartość godziny w zakres od 0 do 11 (aby dopasować odpowiedni znak Unicode dla każdej godziny) i zapisujemy początkową część wyniku, w tym pierwsza tarcza zegara.

W tym momencie musimy podążać za różnymi gałęziami w zależności od tego, które składniki są niezerowe. Pierwszy test, na początku linii piątej, sprawdza tylko, czy minuty i sekundy są równe zero. Jeśli tak, wypisujemy finał .i wychodzimy. W przeciwnym razie wiersze szósty i siódmy zajmują się pozostałymi przypadkami - wypisanie odpowiedniego tekstu i wartości, zanim wszystkie ścieżki ponownie połączą się w wierszu piątym, aby zapisać ostatnią tarczę zegara (wykonywanie od prawej do lewej).

James Holderness
źródło
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):''))

Mniej golfa

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)
      : ''
    )
)

Test

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>

edc65
źródło
Nie wiem, jak wybrać zwycięzcę, oboje opublikowaliście w odległości 2 minut od siebie z 201 bajtami w tym samym języku.
Magic Octopus Urn
@ carusocomputing oczywiście powinieneś mnie wybrać. Mnie. JA JA JA! ...
edc65,
@carusocomputing, albo możesz wybrać odpowiedź, która ma mniej głosów (bez powodu) tylko po to, aby odzyskać równowagę
edc65
Lub możesz zamienić słowo Stringw kodzie ""na pusty ciąg, aby zaoszczędzić 4 bajty :). Ach, cholera, on też może.
Magic Octopus Urn
Pokazy It is currently 🕛 with 60 minutes until 🕐. Myślę, że powinnoIt is currently 🕛.
Roman Gräf
2

JavaScript (ES6), 201 bajtów

(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 bajtów, jeśli weźmiesz pod uwagę liczbę mnogą:

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>

Neil
źródło
1

PowerShell , 250 243 bajtów

$h,$m,$s=$args-split':'
$f={[char]::ConvertFromUtf32(128336+(11+$args[0])%12)}
$u=(60-$s)%60
$v=(59-$m+!$u)%60
"It is currently $(&$f $h;"with $(("$v minutes"|?{$v}),("$u seconds"|?{$u})-match'.'-join' and ') until $(&$f (1+$h))"|?{$u-or$v})."

Wypróbuj online!

briantist
źródło
1

C, 241 bajtów

Zapisuje UTF-8 na standardowe wyjście.

#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".");}

Wypróbuj online!

Kod z białymi znakami:

#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".");
}
nwellnhof
źródło