मान लीजिए कि हमारे पास पूर्णांकों की एक सरणी है, हमें यह जांचना होगा कि क्या सरणी में दो अलग-अलग सूचकांक i और j हैं जैसे कि nums[i] और nums[j] के बीच पूर्ण अंतर अधिकतम टी. और i और j के बीच पूर्ण अंतर अधिकतम k है। इसलिए यदि इनपुट [1,2,3,1] जैसा है, तो यदि k =3 और t =0 है, तो सही लौटें।
इसे हल करने के लिए, हम इन चरणों का पालन करेंगे -
-
एक सेट बनाएं s, n :=nums array का आकार
-
मैं के लिए 0 से n - 1 की सीमा में
-
x अंक [i] और ऊपर से शुरू होने वाले सेट तत्व की अनुक्रमणिका है
-
यदि x सेट की सीमा में नहीं है और x <=nums[i] + t का मान है, तो सही लौटें
-
अगर x पहला तत्व नहीं है
-
x :=अगला तत्व यादृच्छिक के रूप में
-
यदि x से शुरू होने वाला t वां तत्व>=nums[i] है, तो सही लौटें
-
-
nums[i] को s में डालें, फिर nums[i - k] को s से हटाएँ
-
-
झूठी वापसी
उदाहरण(C++)
आइए एक बेहतर समझ प्राप्त करने के लिए निम्नलिखित कार्यान्वयन देखें -
#include <bits/stdc++.h> using namespace std; class Solution { public: bool containsNearbyAlmostDuplicate(vector<int>& nums, int k, int t) { multiset <int> s; int n = nums.size(); for(int i = 0; i< n; i++){ multiset <int> :: iterator x = s.lower_bound(nums[i]); if(x != s.end() && *x <= nums[i] + t ) return true; if(x != s.begin()){ x = std::next(x, -1); if(*x + t >= nums[i])return true; } s.insert(nums[i]); if(i >= k){ s.erase(nums[i - k]); } } return false; } }; main(){ Solution ob; vector<int> v = {1,2,3,1}; cout << (ob.containsNearbyAlmostDuplicate(v, 3,0)); }
इनपुट
[1,2,3,1] 3 0
आउटपुट
1