สมมติว่าเรามีเวลาที่แสดงในรูปแบบ "HH:MM" เราต้องสร้างเวลาที่ใกล้เคียงที่สุดถัดไปโดยใช้ตัวเลขปัจจุบันซ้ำ ใช้เลขได้ไม่จำกัดจำนวนครั้ง
ดังนั้น หากอินพุตเป็นเหมือน "19:34" เอาต์พุตจะเป็น "19:39" เนื่องจากเวลาที่ใกล้เคียงที่สุดถัดไปโดยเลือกจากหลัก 1, 9, 3, 4, คือ 19:39 ไม่ใช่ 19:33 น. เพราะสิ่งนี้เกิดขึ้น 23 ชั่วโมง 59 นาทีต่อมา
เพื่อแก้ปัญหานี้ เราจะทำตามขั้นตอนเหล่านี้ -
-
กำหนดฟังก์ชัน eval() ซึ่งจะใช้ x
-
a :=แปลง x[0] เป็นสตริง
-
a :=a + x[1]
-
b :=แปลง x[2] เป็นสตริง
-
b :=b + x[3]
-
คืนค่า a เป็นจำนวนเต็ม * 60 + b เป็นจำนวนเต็ม
-
จากวิธีหลัก ให้ทำดังต่อไปนี้ −
-
ret :=สตริงว่าง
-
temp :=สตริงว่าง
-
diff :=inf
-
กำหนดเวลาอาร์เรย์
-
ใส่ t[0] เมื่อสิ้นสุดเวลา
-
ใส่ t[1] เมื่อสิ้นสุดเวลา
-
ใส่ t[3] เมื่อสิ้นสุดเวลา
-
ใส่ t[4] เมื่อสิ้นสุดเวลา
-
n :=ขนาดเวลา
-
src :=สตริงว่าง
-
temp1 :=สตริงว่าง
-
temp2 :=สตริงว่าง
-
สำหรับการเริ่มต้น i :=0 เมื่อ i
-
src :=src + เวลา[i]
-
-
สำหรับการเริ่มต้น i :=0 เมื่อ i
-
สำหรับการเริ่มต้น j :=0 เมื่อ j
-
สำหรับการเริ่มต้น k :=0 เมื่อ k
-
สำหรับการเริ่มต้น l :=0 เมื่อ l
-
temp1 :=เวลา[i]
-
temp1 :=temp1 + เวลา[j]
-
temp2 :=เวลา[k]
-
temp2 :=temp2 + เวลา[l]
-
ถ้า temp1 เป็นตัวเลข> 23 หรือ temp2 เป็นตัวเลข> 59 แล้ว −
-
ละเว้นส่วนต่อไปนี้ ข้ามไปยังการทำซ้ำถัดไป
-
-
อุณหภูมิ :=temp1 + temp2
-
ถ้า temp เท่ากับ src แล้ว −
-
ละเว้นส่วนต่อไปนี้ ข้ามไปยังการทำซ้ำถัดไป
-
-
newDiff :=eval(temp - eval(src))
-
ถ้า newDiff <0 แล้ว −
-
newDiff :=newDiff + (60 * 24)
-
-
ถ้า newDiff
-
diff :=newDiff
-
ret :=temp1 + ":" + temp2
-
-
-
-
-
return (ถ้าขนาดของ ret เท่ากับ 0 แล้ว t มิฉะนั้น ret)
ตัวอย่าง
ให้เราดูการใช้งานต่อไปนี้เพื่อความเข้าใจที่ดีขึ้น -
#include <bits/stdc++.h> using namespace std; class Solution { public: int eval(string x){ string a = to_string(x[0]); a += x[1]; string b = to_string(x[2]); b += x[3]; return stoi(a) * 60 + stoi(b); } string nextClosestTime(string t) { string ret = ""; string temp = ""; int diff = INT_MAX; vector<char> time; time.push_back(t[0]); time.push_back(t[1]); time.push_back(t[3]); time.push_back(t[4]); int n = time.size(); string src = ""; string temp1 = ""; string temp2 = ""; for (int i = 0; i < n; i++) src += time[i]; for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { for (int k = 0; k < n; k++) { for (int l = 0; l < n; l++) { temp1 = time[i]; temp1 += time[j]; temp2 = time[k]; temp2 += time[l]; if (stoi(temp1) > 23 || stoi(temp2) > 59) continue; temp = temp1 + temp2; if (temp == src) continue; int newDiff = eval(temp) - eval(src); if (newDiff < 0) newDiff += (60 * 24); if (newDiff < diff) { diff = newDiff; ret = temp1 + ":" + temp2; } } } } } return ret.size() == 0 ? t : ret; } }; main(){ Solution ob; cout<<(ob.nextClosestTime("19:34")); }
อินพุต
"19:34"
ผลลัพธ์
19:39