मान लीजिए कि हमारे पास 4 अंकों की एक सरणी है, हमें 24 घंटे का सबसे बड़ा समय निकालना होगा जो बनाया जा सकता है। हम जानते हैं कि 24 घंटे का सबसे छोटा समय 00:00 है, और सबसे बड़ा समय 23:59 है। 00:00 से शुरू होकर, यदि मध्यरात्रि के बाद से अधिक समय बीत चुका है, तो समय बड़ा होता है। हमें उत्तर को लंबाई 5 की एक स्ट्रिंग के रूप में वापस करना होगा। यदि वापस करने के लिए कोई वैध समय नहीं है, तो एक खाली स्ट्रिंग लौटाएं।
इसलिए, अगर इनपुट [1,2,3,4] जैसा है, तो आउटपुट "23:41" होगा
इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -
- एक फ़ंक्शन को परिभाषित करें isValid(), यह एक स्ट्रिंग लेगा,
- यदि a[0]> '2', तो −
- झूठी वापसी
- यदि a[0] '2' और a[1]> '3' के समान है, तो −
- झूठी वापसी
- यदि a[3]> '5', तो −
- झूठी वापसी
- सही लौटें
- एक फ़ंक्शन dfs() को परिभाषित करें, यह एक सरणी A, res, cur, लेगा
- यदि वक्र का आकार 5 के समान है, तो −
- अगर isValid(cur) and cur>res, तो −
- res :=cur
- वापसी
- अगर isValid(cur) and cur>res, तो −
- इनिशियलाइज़ i :=0 के लिए, जब i <4, अपडेट करें (i को 1 से बढ़ाएँ), −
- करें
- यदि A[i] -1 के बराबर नहीं है, तो −
- tmp:=ए[i]
- cur :=cur + A[i] + ASCII का '0'
- यदि वक्र का आकार 2 के समान है, तो −
- cur:=वक्र ':' के साथ संयोजित होता है
- ए[i] :=-1
- dfs(A, res, cur)
- ए[i] :=tmp
- cur से अंतिम तत्व हटाएं
- यदि वक्र का आकार 2 के समान है, तो −
- cur से अंतिम तत्व हटाएं
- यदि A[i] -1 के बराबर नहीं है, तो −
- मुख्य विधि से निम्न कार्य करें -
- res:=खाली स्ट्रिंग, tmp:=खाली स्ट्रिंग
- dfs(ए, रेस, टीएमपी)
- रिटर्न रेस
आइए बेहतर समझ पाने के लिए निम्नलिखित कार्यान्वयन देखें -
उदाहरण
#include <bits/stdc++.h> using namespace std; class Solution { public: void dfs(vector<int>& A, string& res, string& cur) { if (cur.size() == 5) { if (isValid(cur) && cur > res) res = cur; return; } for (int i = 0; i < 4; ++i) { if (A[i] != -1) { int tmp = A[i]; cur += A[i] + '0'; if (cur.size() == 2) cur += ':'; A[i] = -1; dfs(A, res, cur); A[i] = tmp; cur.pop_back(); if (cur.size() == 2) cur.pop_back(); } } } bool isValid(const string a) { if (a[0] > '2') return false; if (a[0] == '2' && a[1] > '3') return false; if (a[3] > '5') return false; return true; } string largestTimeFromDigits(vector<int>& A) { string res = "", tmp = ""; dfs(A, res, tmp); return res; } }; main(){ Solution ob; vector<int> v = {1,2,3,4}; cout << (ob.largestTimeFromDigits(v)); }
इनपुट
{1,2,3,4}
आउटपुट
23:41