अवरोही क्रम में सॉर्ट किया मुझे समझ में एक महत्वपूर्ण की तुलना में कम है कि इस कार्य find_if() एसटीएल-एल्गोरिथ्म समारोह का उपयोग कर के रूप में निम्नानुसार पूरा किया जा सकता का पता लगाएं परिणामस्वरूप लॉगरिदमिक समय में प्राप्त किया जा सकता है। चूंकि वेक्टर पहले ही अवरोही क्रम में क्रमबद्ध है, इसलिए मैं एक बाइनरी खोज दृष्टिकोण का उपयोग करना चाहता हूं।पहला तत्व सख्ती से एक वेक्टर आदेश
मैं समझता हूं कि एसटीएल एल्गोरिदम फ़ंक्शन lower_bound
और upper_bound
लॉगरिदमिक जटिलता की गारंटी देता है। हालांकि मैं यह समझने में असमर्थ हूं कि कुंजी के मुकाबले पहले तत्व को प्राप्त करने के लिए इन तत्वों का उपयोग कैसे करें, क्योंकि किसी कुंजी से अधिक या उसके बराबर पहले तत्व के विपरीत।
उदाहरण के लिए:
मान लीजिए मेरी वेक्टर सामग्री हैं: 21 9 8 7 6 4
मेरे कुंजी है: 10
मैं उत्पादन 9
होना चाहता हूँ, क्योंकि एक में अपना पहला तत्व दाएं से बाएं 10
से कम वेक्टर का स्कैन करें।
इस संबंध में कोई भी मदद बहुत उपयोगी होगी!
धन्यवाद
है [इस] (https://stackoverflow.com/questions/13399243/how-to-find-the-first-smaller-element-than- एक-पूर्णांक-एक्स-इन-ए-वेक्टर-सी) लेकिन आपको आगे की खोज के लिए पीछे की ओर खोज को बदलना होगा। – NathanOliver