LISP - सेट करें

आम लिस्प एक सेट डेटा प्रकार प्रदान नहीं करता है। हालांकि, यह उन कार्यों की संख्या प्रदान करता है जो सेट संचालन को किसी सूची में करने की अनुमति देता है।

आप विभिन्न मानदंडों के आधार पर सूची में आइटम जोड़ सकते हैं, निकाल सकते हैं और खोज सकते हैं। आप विभिन्न सेट ऑपरेशन भी कर सकते हैं जैसे: यूनियन, चौराहा और सेट अंतर।

LISP में सेट लागू करना

सेट, जैसे सूचियाँ आम तौर पर विपक्ष कोशिकाओं के संदर्भ में कार्यान्वित की जाती हैं। हालाँकि, इस कारण से, सेट संचालन कम और कम कुशल हो जाता है जितना बड़ा सेट मिलता है।

adjoinफ़ंक्शन आपको एक सेट बनाने की अनुमति देता है। यह एक आइटम और एक सूची लेता है जो एक सेट का प्रतिनिधित्व करता है और एक सूची देता है जो मूल सेट में आइटम और सभी आइटमों का प्रतिनिधित्व करता है।

adjoinफ़ंक्शन पहले दिए गए सूची में आइटम की तलाश करता है, अगर यह पाया जाता है, तो यह मूल सूची को वापस कर देता है; अन्यथा यह अपने साथ एक नया वाणिज्य प्रकोष्ठ बनाता हैcar आइटम के रूप में और cdr मूल सूची की ओर इशारा करते हुए और यह नई सूची लौटाता है।

adjoin फंक्शन भी लेता है :key तथा :testकीवर्ड तर्क। इन तर्कों का उपयोग यह जांचने के लिए किया जाता है कि क्या आइटम मूल सूची में मौजूद है।

चूंकि, आसन्न फ़ंक्शन मूल सूची को संशोधित नहीं करता है, सूची में खुद को बदलने के लिए, आपको या तो मूल सूची से सटे हुए मान को वापस करना होगा या, आप मैक्रो का उपयोग कर सकते हैं pushnew सेट में एक आइटम जोड़ने के लिए।

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

; creating myset as an empty list
(defparameter *myset* ())
(adjoin 1 *myset*)
(adjoin 2 *myset*)

; adjoin did not change the original set
;so it remains same
(write *myset*)
(terpri)
(setf *myset* (adjoin 1 *myset*))
(setf *myset* (adjoin 2 *myset*))

;now the original set is changed
(write *myset*)
(terpri)

;adding an existing value
(pushnew 2 *myset*)

;no duplicate allowed
(write *myset*)
(terpri)

;pushing a new value
(pushnew 3 *myset*)
(write *myset*)
(terpri)

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

NIL
(2 1)
(2 1)
(3 2 1)

सदस्यता जाँच रहा है

फ़ंक्शन का सदस्य समूह आपको यह जांचने की अनुमति देता है कि कोई तत्व किसी सेट का सदस्य है या नहीं।

इन कार्यों के वाक्य विन्यास निम्नलिखित हैं -

member item list &key :test :test-not :key 
member-if predicate list &key :key 
member-if-not predicate list &key :key

ये फ़ंक्शन किसी दिए गए आइटम के लिए दी गई सूची को खोजते हैं जो परीक्षण को संतुष्ट करता है। यदि ऐसा कोई आइटम नहीं मिला है, तो फ़ंक्शन वापस लौटता हैnil. अन्यथा, पहले तत्व के रूप में तत्व के साथ सूची की पूंछ वापस आ गई है।

खोज केवल शीर्ष स्तर पर की जाती है।

इन कार्यों को विधेय के रूप में इस्तेमाल किया जा सकता है।

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(write (member 'zara '(ayan abdul zara riyan nuha)))
(terpri)
(write (member-if #'evenp '(3 7 2 5/3 'a)))
(terpri)
(write (member-if-not #'numberp '(3 7 2 5/3 'a 'b 'c)))

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

(ZARA RIYAN NUHA)
(2 5/3 'A)
('A 'B 'C)

यूनियन सेट करें

फ़ंक्शन का संघ समूह आपको परीक्षण के आधार पर इन कार्यों के तर्क के रूप में प्रदान की गई दो सूचियों पर सेट यूनियन प्रदर्शन करने की अनुमति देता है।

इन कार्यों के वाक्य विन्यास निम्नलिखित हैं -

union list1 list2 &key :test :test-not :key 
nunion list1 list2 &key :test :test-not :key

unionफ़ंक्शन दो सूची लेता है और दोनों सूची में मौजूद सभी तत्वों से युक्त एक नई सूची देता है। यदि डुप्लीकेशंस हैं, तो सदस्य की केवल एक प्रति लौटी सूची में रखी गई है।

nunion फ़ंक्शन समान ऑपरेशन करता है लेकिन तर्क सूचियों को नष्ट कर सकता है।

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(setq set1 (union '(a b c) '(c d e)))
(setq set2 (union '(#(a b) #(5 6 7) #(f h)) 
   '(#(5 6 7) #(a b) #(g h)) :test-not #'mismatch)
)
       
(setq set3 (union '(#(a b) #(5 6 7) #(f h)) 
   '(#(5 6 7) #(a b) #(g h)))
)
(write set1)
(terpri)
(write set2)
(terpri)
(write set3)

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

(A B C D E)
(#(F H) #(5 6 7) #(A B) #(G H))
(#(A B) #(5 6 7) #(F H) #(5 6 7) #(A B) #(G H))

कृपया ध्यान दें

संघ कार्य बिना अपेक्षा के काम नहीं करता है :test-not #'mismatchतीन वैक्टर की एक सूची के लिए तर्क। इसका कारण यह है, सूचियाँ कॉन्स कोशिकाओं से बनी होती हैं और हालाँकि ये मान हमें स्पष्ट रूप से एक जैसे लगते हैंcdrकोशिकाओं का हिस्सा मेल नहीं खाता है, इसलिए वे LISP दुभाषिया / संकलक के समान नहीं हैं। यही कारण है; सूचियों का उपयोग करके बड़े सेट लागू करने की सलाह नहीं दी जाती है। यह छोटे सेट के लिए ठीक काम करता है।

अंतःकरण सेट करें

कार्यों का चौराहा समूह आपको एक परीक्षण के आधार पर इन कार्यों के तर्क के रूप में प्रदान की गई दो सूचियों पर प्रतिच्छेदन करने की अनुमति देता है।

इन कार्यों के वाक्य विन्यास निम्नलिखित हैं -

intersection list1 list2 &key :test :test-not :key 
nintersection list1 list2 &key :test :test-not :key

ये फ़ंक्शन दो सूचियाँ लेते हैं और दोनों तर्क सूचियों में मौजूद सभी तत्वों से युक्त एक नई सूची लौटाते हैं। यदि या तो सूची में डुप्लिकेट प्रविष्टियाँ हैं, तो अनावश्यक प्रविष्टियाँ परिणाम में दिखाई दे सकती हैं या नहीं।

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(setq set1 (intersection '(a b c) '(c d e)))
(setq set2 (intersection '(#(a b) #(5 6 7) #(f h)) 
   '(#(5 6 7) #(a b) #(g h)) :test-not #'mismatch)
)
       
(setq set3 (intersection '(#(a b) #(5 6 7) #(f h)) 
   '(#(5 6 7) #(a b) #(g h)))
)
(write set1)
(terpri)
(write set2)
(terpri)
(write set3)

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

(C)
(#(A B) #(5 6 7))
NIL

चौराहे समारोह चौराहे का विनाशकारी संस्करण है, अर्थात, यह मूल सूचियों को नष्ट कर सकता है।

अंतर सेट करें

कार्यों का समूह-अंतर समूह आपको एक परीक्षण के आधार पर इन कार्यों के तर्क के रूप में प्रदान की गई दो सूचियों पर सेट अंतर करने की अनुमति देता है।

इन कार्यों के वाक्य विन्यास निम्नलिखित हैं -

set-difference list1 list2 &key :test :test-not :key 
nset-difference list1 list2 &key :test :test-not :key

सेट-डिफरेंस फ़ंक्शन पहली सूची के तत्वों की एक सूची देता है जो दूसरी सूची में दिखाई नहीं देते हैं।

उदाहरण

Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।

(setq set1 (set-difference '(a b c) '(c d e)))
(setq set2 (set-difference '(#(a b) #(5 6 7) #(f h)) 
   '(#(5 6 7) #(a b) #(g h)) :test-not #'mismatch)
)
(setq set3 (set-difference '(#(a b) #(5 6 7) #(f h)) 
   '(#(5 6 7) #(a b) #(g h)))
)
(write set1)
(terpri)
(write set2)
(terpri)
(write set3)

जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -

(A B)
(#(F H))
(#(A B) #(5 6 7) #(F H))