मिलान मैं तत्वों (संभावित बड़ा) एक आदेश संबंध के साथ का एक सेट है itemset मेरे पास आदेशित सेट का अनुक्रम है:एल्गोरिथ्म पैटर्न
[a,b], [e], [c], [e,f], [a,b,c]
मैं अनुक्रम में प्रत्येक सेट को संबंधित पेट के आईडी के साथ मिलान करना चाहता हूं ट्रंस:
[a,b]:{1,2,4}, [e]:{}, [c]:{3}, [a,b,c]:{1,2,3,4,5,6}
मेरा लक्ष्य अनुक्रम के ऊपर से गुजरता की संख्या को सीमित करने के लिए है तो मैं एक डेटा संरचना मैं स्कैन के दौरान उपयोग कर सकते हैं का निर्माण करना चाहते। मैं एक उपसर्ग पेड़ की सोच रहा हूँ:
──null
├──a : 1
| |
| └──b : 4
| |
| └──c : { 5, 6 }
|
├──b : 2
| |
| └──c : 5
|
└──c : 3
मैं अनुक्रम में एक सेट स्कैन और यह पेड़ कई बार रिकर्सिवली (सेट, set.tail, set.tail.tail गर्त पारित ...), हर बार जब मैं एक नोड तक पहुंचता हूं तो मैं एक सरणी में संबंधित आईडी जोड़ता हूं।
क्या मुझे अपने तर्क में किसी भी असाधारण मामले को याद आती है (मुझे एहसास हुआ कि मुझे depth>2
के नोड्स के लिए एकाधिक आईडी डालना है यदि मैं [ए, सी] याद नहीं करना चाहता हूं यदि [ए, बी, सी] मौजूद है सेट) ? क्या कोई और परिष्कृत डेटा संरचना है जिसका उपयोग मैं प्रसंस्करण समय में सुधार के लिए कर सकता हूं?
संपादित करें: वास्तव में गहराई से, मुझे अपनी विधि के साथ 2^(n-2)
आईडी की आवश्यकता है (मेरे पेड़ को घने पर विचार करना)। मुझे यकीन है कि यह यह करने के लिए एक वैध तरीका है नहीं कर रहा हूँ ...
EDIT2: एक और दृष्टिकोण अनुक्रम (के रूप में SPADE एल्गोरिथ्म में प्रयुक्त) प्रत्येक पैटर्न का निर्माण करने के लिए प्रत्येक एकल तत्व की बिटमैप्स मिल जाती हैं।
a : [1,0,0,0,1]
b : [0,1,0,0,1]
ab : [0,0,0,0,1]
कुछ सरणी जोड़ों के साथ, मुझे इसे अपने प्रारंभिक सरणी के तत्वों से मिलान करने में सक्षम होना चाहिए।
आप एक DFA ("शब्दकोश इंजन") का निर्माण एक धारा में पहचान करने के लिए * सभी * छह पैटर्न कर सकते हैं।(यह अनिवार्य रूप से fgrep करता है) – wildplasser
@ विल्डप्लेसर, मेरे पास संभावित रूप से बहुत से तत्व और पैटर्न हैं (केवल बाधाओं को पैटर्न में सॉर्ट किया गया है), क्या डीएफए अभी भी एक वैध दृष्टिकोण है? क्या आपके पास प्रत्यारोपण के लिए कोई संदर्भ है? – Alex
http://www.dcs.kcl.ac.uk/staff/mac/TSP/http://www.dcs.kcl.ac.uk/staff/mac/TSP/ (पहला अध्याय, पृष्ठ 47, आईआईआरसी) या संभवतः ड्रैगन पुस्तक। – wildplasser