ความท้าทายเป็นเรื่องง่ายกำหนดเวลาอินพุตเป็นสตริงในรูปแบบใดรูปแบบหนึ่งต่อไปนี้:
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.
คุณไม่จำเป็นต้องสอดคล้องกับรูปแบบของผลลัพธ์ใด ๆ สำหรับกรณีที่ไม่ถูกต้องข้อผิดพลาดได้
โดยรวมแล้วความท้าทายค่อนข้างง่าย แต่ดูเหมือนจะมีพลังมากพอที่จะสนุกในความคิดของฉัน รหัสที่สั้นที่สุดในที่นี้คือผู้ชนะเนื่องจากไม่มีความกว้างของตัวแปรมากไปกว่ารหัสอื่น ๆ
0 < hh < 24
, 0 < mm < 60
และ0 < ss < 60
คุณหมาย0 ≤ hh ≤ 23
, และ0 ≤ mm ≤ 59
0 ≤ ss ≤ 59
AM
หรือPM
แท็ก?