मान लीजिए हमारे पास एक बाइनरी सरणी है; अगर हम ज़्यादा से ज़्यादा एक 0 पर फ़्लिप कर सकते हैं, तो हमें इस सरणी में लगातार 1s की अधिकतम संख्या ज्ञात करनी होगी।
इसलिए, यदि इनपुट [1,0,1,1,0] जैसा है, तो आउटपुट 4 होगा क्योंकि यदि हम पहले शून्य को फ्लिप करते हैं तो लगातार 1s की अधिकतम संख्या प्राप्त होगी। फ़्लिप करने के बाद, लगातार 1s की अधिकतम संख्या 4 होती है।
इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -
-
रिट:=1, एन:=अंकों का आकार
-
यदि नहीं n गैर-शून्य है, तो -
-
वापसी 0
-
-
जे:=0, शून्य:=0
-
इनिशियलाइज़ i:=0 के लिए, जब i
-
अगर nums[i] 0 के समान है, तो -
-
(शून्य को 1 से बढ़ाएं)
-
-
जबकि (j <=i और शून्य> 1), करें -
-
अगर nums[j] 0 के समान है, तो -
-
(शून्य को 1 से घटाएं)
-
-
(जम्मू को 1 से बढ़ाएं)
-
-
ret :=अधिकतम रिट और (i - j + 1)
-
-
वापसी रिट
उदाहरण
आइए बेहतर समझ पाने के लिए निम्नलिखित कार्यान्वयन देखें -
#include <bits/stdc++.h> using namespace std; class Solution { public: int findMaxConsecutiveOnes(vector<int<& nums) { int ret = 1; int n = nums.size(); if (!n) return 0; int j = 0; int zero = 0; for (int i = 0; i < n; i++) { if (nums[i] == 0) { zero++; } while (j <= i && zero > 1) { if (nums[j] == 0) { zero--; } j++; } ret = max(ret, i - j + 1); } return ret; } }; main(){ Solution ob; vector<int< v = {1,0,1,1,1,0,1,1}; cout << (ob.findMaxConsecutiveOnes(v)); }
इनपुट
{1,0,1,1,1,0,1,1}
आउटपुट
6