ধরুন আমরা "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]
-
একটি পূর্ণসংখ্যা হিসাবে ফেরত দিন * 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, তাহলে −
-
নিম্নলিখিত অংশ উপেক্ষা করুন, পরবর্তী পুনরাবৃত্তি এড়িয়ে যান
-
-
temp :=temp1 + temp2
-
যদি temp src এর মত হয়, তাহলে −
-
নিম্নলিখিত অংশ উপেক্ষা করুন, পরবর্তী পুনরাবৃত্তি এড়িয়ে যান
-
-
newDiff :=eval(temp - eval(src))
-
যদি newDiff <0, তাহলে −
-
newDiff :=newDiff + (60 * 24)
-
-
যদি newDiff
-
diff :=newDiff
-
ret :=temp1 + ":" + temp2
-
-
-
-
-
রিটার্ন (যদি 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