LISP - अनुक्रम
अनुक्रम LISP में एक सार डेटा प्रकार है। वैक्टर और सूचियाँ इस डेटा प्रकार के दो ठोस उपप्रकार हैं। अनुक्रम डेटा प्रकार पर परिभाषित सभी फ़ंक्शंस वास्तव में सभी वैक्टर और सूची प्रकारों पर लागू होते हैं।
इस खंड में, हम अनुक्रमों पर सबसे अधिक इस्तेमाल किए जाने वाले कार्यों पर चर्चा करेंगे।
अनुक्रमों (यानी, वैक्टर और सूचियों) में हेरफेर करने के विभिन्न तरीकों पर शुरू करने से पहले, आइए हम सभी उपलब्ध कार्यों की सूची पर एक नज़र डालें।
अनुक्रम बनाना
फ़ंक्शन मेक-सीक्वेंस आपको किसी भी प्रकार का एक सीक्वेंस बनाने की अनुमति देता है। इस फ़ंक्शन का सिंटैक्स है -
make-sequence sqtype sqsize &key :initial-element
यह प्रकार sqtype और लंबाई sqsize का एक क्रम बनाता है ।
आप वैकल्पिक रूप से : प्रारंभिक-तत्व तर्क का उपयोग करके कुछ मान निर्दिष्ट कर सकते हैं , फिर प्रत्येक तत्व को इस मान से आरंभ किया जाएगा।
उदाहरण के लिए, main.lisp नाम से एक नया स्रोत कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (make-sequence '(vector float)
10
:initial-element 1.0))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0)
अनुक्रम पर सामान्य कार्य
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | elt यह एक पूर्णांक सूचकांक के माध्यम से व्यक्तिगत तत्वों तक पहुंच की अनुमति देता है। |
2 | length यह एक अनुक्रम की लंबाई लौटाता है। |
3 | subseq यह एक विशेष सूचकांक पर शुरू होने वाले अनुक्रम को निकालने और एक विशेष समाप्ति सूचकांक या अनुक्रम के अंत तक जारी रखते हुए एक उप-अनुक्रम देता है। |
4 | copy-seq यह एक अनुक्रम देता है जिसमें उसके तर्क के समान तत्व होते हैं। |
5 | fill यह एक अनुक्रम के कई तत्वों को एकल मान पर सेट करने के लिए उपयोग किया जाता है। |
6 | replace इसमें दो क्रम लगते हैं और पहला तर्क अनुक्रम विनाशकारी रूप से दूसरे तर्क अनुक्रम से इसमें क्रमिक तत्वों को कॉपी करके संशोधित किया जाता है। |
7 | count यह एक आइटम और एक अनुक्रम लेता है और अनुक्रम में आइटम के प्रकट होने की संख्या को वापस करता है। |
8 | reverse यह एक अनुक्रम देता है जिसमें तर्क के समान तत्व होते हैं लेकिन रिवर्स ऑर्डर में। |
9 | nreverse यह उसी अनुक्रम को देता है जिसमें अनुक्रम के समान तत्व होते हैं लेकिन रिवर्स ऑर्डर में। |
10 | concatenate यह एक नए अनुक्रम का निर्माण करता है जिसमें किसी भी संख्या के अनुक्रम का संयोजन होता है। |
1 1 | position यह एक आइटम और एक अनुक्रम लेता है और अनुक्रम या नील में आइटम के सूचकांक को वापस करता है। |
12 | find यह एक आइटम और एक अनुक्रम लेता है। यह अनुक्रम में आइटम को ढूंढता है और इसे वापस लौटाता है, यदि नहीं मिला है तो यह शून्य देता है। |
13 | sort यह एक अनुक्रम लेता है और एक दो-तर्क विधेय करता है और अनुक्रम का एक क्रमबद्ध संस्करण लौटाता है। |
14 | merge यह दो अनुक्रमों और एक विधेय को लेता है और एक अनुक्रम को दो अनुक्रमों को विलय करके उत्पादित करता है, जो कि विधेय के अनुसार है। |
15 | map यह एक n- तर्क फ़ंक्शन और n अनुक्रम लेता है और अनुक्रम के बाद के तत्वों में फ़ंक्शन को लागू करने के परिणामस्वरूप एक नया अनुक्रम देता है। |
16 | some यह एक तर्क के रूप में एक विधेय लेता है और तर्क अनुक्रम पर पुनरावृत्ति करता है, और विधेय द्वारा लौटाया गया पहला गैर-एनआईएल मान लौटाता है या यदि विधेय कभी संतुष्ट नहीं होता है तो वापस लौटता है। |
17 | every यह एक तर्क के रूप में एक विधेय लेता है और तर्क अनुक्रम पर पुनरावृति करता है, यह समाप्त होता है, जैसे ही विधेय विफल होता है, वापस लौटता है। यदि विधेय हमेशा संतुष्ट रहता है, तो यह सच है। |
18 | notany यह एक तर्क के रूप में एक विधेय लेता है और तर्क अनुक्रम पर पुनरावृति करता है, और झूठे के रूप में जल्द ही लौट जाता है यदि विधेय संतुष्ट या सच है यदि यह कभी नहीं है। |
19 | notevery यह एक तर्क के रूप में एक विधेय लेता है और तर्क अनुक्रम पर पुनरावृति करता है, और जैसे ही विधेय हमेशा संतुष्ट होता है, वैसे ही विधेय विफल या गलत होने पर वापस लौटता है। |
20 | reduce यह अनुक्रम के पहले दो तत्वों के लिए पहले दो-तर्क फ़ंक्शन को लागू करता है और फिर अनुक्रम द्वारा दिए गए मान और उसके बाद के तत्वों पर लौटाए गए एकल अनुक्रम पर मैप करता है। |
21 | search यह कुछ परीक्षण को संतुष्ट करने वाले एक या अधिक तत्वों का पता लगाने के लिए एक क्रम को खोजता है। |
22 | remove यह एक आइटम और एक अनुक्रम लेता है और हटाए गए आइटम के उदाहरणों के साथ अनुक्रम लौटाता है। |
23 | delete यह एक आइटम और एक अनुक्रम भी लेता है और तर्क क्रम का उसी प्रकार का अनुक्रम देता है जिसमें आइटम को छोड़कर समान तत्व होते हैं। |
24 | substitute यह एक नया आइटम, एक मौजूदा आइटम और एक अनुक्रम लेता है और नए आइटम के साथ प्रतिस्थापित मौजूदा आइटम के उदाहरणों के साथ एक अनुक्रम देता है। |
25 | nsubstitute यह एक नया आइटम, एक मौजूदा आइटम और एक अनुक्रम लेता है और उसी क्रम को मौजूदा आइटम के उदाहरणों के साथ नए आइटम के साथ बदल देता है। |
26 | mismatch यह दो क्रम लेता है और बेमेल तत्वों की पहली जोड़ी का सूचकांक देता है। |
मानक अनुक्रम समारोह कीवर्ड तर्क
बहस | जिसका अर्थ है | डिफ़ॉल्ट मान |
---|---|---|
:परीक्षा | यह एक दो-तर्क फ़ंक्शन है जिसका उपयोग आइटम (या मुख्य फ़ंक्शन द्वारा निकाले गए मूल्य) की तुलना करने के लिए किया जाता है। | EQL |
:चाभी | वास्तविक अनुक्रम तत्व से मुख्य मान निकालने के लिए एक-तर्क फ़ंक्शन। NIL का अर्थ है तत्व का उपयोग करें। | शून्य |
:शुरू | अनुक्रमणिका (समावेशी) की शुरुआत। | 0 |
:समाप्त | अंत का सूचकांक (अनन्य)। NIL अनुक्रम के अंत को इंगित करता है। | शून्य |
: अंत से | यदि सही है, तो अनुक्रम को अंत से शुरू होने तक, रिवर्स ऑर्डर में ट्रेस किया जाएगा। | शून्य |
: गिनती | सभी को हटाने के लिए या NIL को हटाने या प्रतिस्थापित करने के लिए तत्वों की संख्या को इंगित करने वाली संख्या (केवल REMOVE और SUBSTITUTE)। | शून्य |
हमने विभिन्न कार्यों और खोजशब्दों पर चर्चा की है जो अनुक्रमों पर काम करने वाले इन कार्यों में तर्क के रूप में उपयोग किए जाते हैं। अगले खंडों में, हम देखेंगे कि उदाहरणों का उपयोग करके इन कार्यों का उपयोग कैसे करें।
लंबाई और तत्व ढूँढना
length फ़ंक्शन एक अनुक्रम की लंबाई देता है, और elt फ़ंक्शन आपको पूर्णांक सूचकांक का उपयोग करके व्यक्तिगत तत्वों तक पहुंचने की अनुमति देता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq x (vector 'a 'b 'c 'd 'e))
(write (length x))
(terpri)
(write (elt x 3))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
5
D
अनुक्रमों को संशोधित करना
कुछ अनुक्रम फ़ंक्शंस अनुक्रम के माध्यम से पुनरावृत्ति की अनुमति देते हैं और कुछ ऑपरेशन करते हैं जैसे, स्पष्ट लूप लिखने के बिना विशिष्ट तत्वों को खोजना, निकालना, गिनना या फ़िल्टर करना।
निम्न उदाहरण यह प्रदर्शित करता है -
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (count 7 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (remove 5 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (delete 5 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (substitute 10 7 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (find 7 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (position 5 '(1 5 6 7 8 9 2 7 3 4 5)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
2
(1 6 7 8 9 2 7 3 4)
(1 6 7 8 9 2 7 3 4)
(1 5 6 10 8 9 2 10 3 4 5)
7
1
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (delete-if #'oddp '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (delete-if #'evenp '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (remove-if #'evenp '(1 5 6 7 8 9 2 7 3 4 5) :count 1 :from-end t))
(terpri)
(setq x (vector 'a 'b 'c 'd 'e 'f 'g))
(fill x 'p :start 1 :end 4)
(write x)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(6 8 2 4)
(1 5 7 9 7 3 5)
(1 5 6 7 8 9 2 7 3 5)
#(A P P P E F G)
क्रमबद्धता और विलय अनुक्रम
सॉर्टिंग फ़ंक्शन एक अनुक्रम लेते हैं और दो-तर्क विधेय करते हैं और अनुक्रम के एक सॉर्ट किए गए संस्करण को वापस करते हैं।
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (sort '(2 4 7 3 9 1 5 4 6 3 8) #'<))
(terpri)
(write (sort '(2 4 7 3 9 1 5 4 6 3 8) #'>))
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(1 2 3 3 4 4 5 6 7 8 9)
(9 8 7 6 5 4 4 3 3 2 1)
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (merge 'vector #(1 3 5) #(2 4 6) #'<))
(terpri)
(write (merge 'list #(1 3 5) #(2 4 6) #'<))
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(1 2 3 4 5 6)
(1 2 3 4 5 6)
अनुक्रम की भविष्यवाणी करता है
प्रत्येक, कुछ, कुछ, नोटरी और नोटरी के कार्यों को अनुक्रम की भविष्यवाणी कहा जाता है।
ये कार्य अनुक्रमों पर पुनरावृति करते हैं और बूलियन का परीक्षण करते हैं।
ये सभी कार्य पहले तर्क के रूप में एक विधेय लेते हैं और शेष तर्क क्रम होते हैं।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (every #'evenp #(2 4 6 8 10)))
(terpri)
(write (some #'evenp #(2 4 6 8 10 13 14)))
(terpri)
(write (every #'evenp #(2 4 6 8 10 13 14)))
(terpri)
(write (notany #'evenp #(2 4 6 8 10)))
(terpri)
(write (notevery #'evenp #(2 4 6 8 10 13 14)))
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
T
T
NIL
NIL
T
मानचित्रण अनुक्रम
हमने मैपिंग फ़ंक्शन पर पहले ही चर्चा की है। इसी प्रकार दmap फ़ंक्शन आपको एक या अधिक अनुक्रम के बाद के तत्वों पर एक फ़ंक्शन लागू करने की अनुमति देता है।
map फ़ंक्शन एक n- तर्क फ़ंक्शन और n अनुक्रम लेता है और बाद के अनुक्रमों के फ़ंक्शन को लागू करने के बाद एक नया अनुक्रम देता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (map 'vector #'* #(2 3 4 5) #(3 5 4 8)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(6 15 16 40)