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)