मैंने रैखिक समय ओ (एन) में आकार एन की सरणी में के-वें सबसे छोटे (या सबसे बड़े) तत्व को खोजने के लिए ऑर्डर आंकड़े पढ़े हैं।मेडियन के औसत
एक कदम है कि इसे मध्यस्थों के औसत को खोजने की आवश्यकता है।
- सरणी को [n/5] भागों में विभाजित करें। प्रत्येक भाग में 5 तत्व होते हैं।
- प्रत्येक भाग में औसत खोजें। (हमारे पास [n/5] संख्याएं हैं)
- चरण 1 और 2 दोहराएं जब तक कि हमारे पास केवल अंतिम संख्या न हो। (अर्थात पुनरावर्ती)
टी (एन) = टी (एन/5) + O (एन) और हम टी (एन) प्राप्त कर सकते हैं = हे (एन)।
लेकिन, क्या यह सच है कि, आखिरकार जो संख्या हम प्राप्त करते हैं वह मध्यस्थों का औसत नहीं है, लेकिन मध्यस्थों के मध्यस्थों के मध्यस्थों के मध्यस्थों का औसत, यदि हमारे पास एक बड़ी सरणी है।
कृपया एक सरणी पर विचार करें जिसमें 125 तत्व हैं।
सबसे पहले, यह 25 भागों में विभाजित है और हमें 25 औसत मिलते हैं। फिर, हम इन 25 संख्याओं को 5 भागों में विभाजित करते हैं और 5 medians, पाते हैं अंत में, हम उस संख्या को प्राप्त करते हैं जो मध्यस्थों के मध्यस्थों का औसत है। (मध्यस्थों का औसत नहीं)
मुझे इसकी परवाह करने का कारण यह है कि, मैं समझ सकता हूं कि [3/4] * एन तत्वों में से अधिकांश हैं जो मध्यस्थों के मध्य से छोटे (या बड़े) हैं। लेकिन क्या होगा यदि यह मध्यस्थों का औसत नहीं है लेकिन मध्यस्थों के मध्यस्थों का औसत है? बदतर मामले में पिटोट की तुलना में छोटे तत्व (या बड़े) होने वाले कम तत्व होने चाहिए, जिसका अर्थ है कि पिवट सरणी की सीमा के करीब है।
यदि हमारे पास बहुत बड़ी सरणी है, और हमने मध्यस्थों के मध्यस्थों के मध्यस्थों के मध्यस्थों के मध्यस्थों का औसत पाया। सबसे बुरे मामले में हमने जो पिवट पाया वह अभी भी बाध्य के बहुत करीब हो सकता है और इस मामले में समय जटिलता क्या है?
मैंने 125 तत्वों का एक डेटासेट बनाया है। परिणाम 9 है?
0.8 0.9 1 inf inf
1.8 1.9 2 inf inf
6.8 6.9 7 inf inf
inf inf inf inf inf
inf inf inf inf inf
2.8 2.9 3 inf inf
3.8 3.9 4 inf inf
7.8 7.9 8 inf inf
inf inf inf inf inf
inf inf inf inf inf
4.8 4.9 5 inf inf
5.8 5.9 6 inf inf
8.8 8.9 9 inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
inf inf inf inf inf
जहां inf का मतलब है कि संख्या काफी बड़ी है।
उत्तर के लिए धन्यवाद! यदि औसत-औसत-मेडियन एल्गोरिदम रिकर्सिव नहीं है, तो आप चरण 3 में क्या करते हैं (मध्यस्थों का औसत खोजें और इसे पिवट के रूप में उपयोग करें)? मेरे आंकड़ों में, 9 27 वां सबसे छोटा नंबर है जिसका मतलब है कि 125 में से 26 संख्या मध्यस्थों के औसत से कम हैं, जो उनमें से लगभग 21% है। – 01zhou
मैं अभी भी गणित का काम कर रहा हूं;) – gramonov
बस अपने पिवट के रूप में चरण 3 में पाए गए मध्यस्थों का औसत उपयोग करें। – gramonov