La sfida è semplicistica, dato un tempo di input come stringa in uno dei seguenti formati:
hh
, hh:mm
O hh:mm:ss
con 0 ≤ hh ≤ 23
, 0 ≤ mm ≤ 59
e 0 ≤ ss ≤ 59
.
Stampa a che ora utilizza i seguenti simboli:
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
Nel seguente formato:
It is currently {Clock Face 1} with {mm} minutes and {ss} seconds until {Clock Face 2}.
Esempi (compresi tutti i casi di frangia):
Caso con solo ore ...
f("12") = "It is currently 🕛."
Caso con ore e minuti ...
f("12:30") = "It is currently 🕛 with 30 minutes until 🕐."
Caso con solo ore, ma ha minuti inclusi come 00 ...
f("12:00") = "It is currently 🕛."
Caso con ore, minuti e secondi ...
f("12:30:30") = "It is currently 🕛 with 29 minutes and 30 seconds until 🕐."
Caso con ore e minuti, ma ha secondi inclusi come 00 ...
f("12:30:00") = "It is currently 🕛 with 30 minutes until 🕐."
Caso con ore e minuti, con meno di un minuto fino all'ora successiva ...
f("12:59:59") = "It is currently 🕛 with 1 seconds until 🕐."
Non è necessario passare dal plurale al singolare.
Caso con ore e minuti, con 1 minuto all'ora successiva ...
f("12:59") = "It is currently 🕛 with 1 minutes until 🕐."
Non è necessario passare dal plurale al singolare.
Caso che utilizza tempo militare (sì, devi gestirlo) ...
f("23:30:30") = "It is currently 🕚 with 29 minutes and 30 seconds until 🕛."
Casi non validi ...
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.
Non è necessario conformarsi a nessuno stile di output per casi non validi, gli errori vanno bene.
Nel complesso la sfida è piuttosto semplicistica, ma sembrava essere abbastanza dinamica da essere divertente secondo me. Il codice più breve qui è il vincitore in quanto non c'è molto aspetto variabile nel codice oltre alla lunghezza.
0 < hh < 24
, 0 < mm < 60
e 0 < ss < 60
, volevi dire 0 ≤ hh ≤ 23
, 0 ≤ mm ≤ 59
e 0 ≤ ss ≤ 59
.
AM
o i PM
tag?