LISP - वैक्टर

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

वैक्टर बनाना

वेक्टर फ़ंक्शन आपको विशिष्ट मानों के साथ निश्चित आकार के वैक्टर बनाने की अनुमति देता है। यह किसी भी संख्या में तर्क लेता है और उन तर्कों वाले वेक्टर को लौटाता है।

उदाहरण 1

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

(setf v1 (vector 1 2 3 4 5))
(setf v2 #(a b c d e))
(setf v3 (vector 'p 'q 'r 's 't))

(write v1)
(terpri)
(write v2)
(terpri)
(write v3)

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

#(1 2 3 4 5)
#(A B C D E)
#(P Q R S T)

कृपया ध्यान दें कि LISP वैक्टर के लिए शाब्दिक अंकन के रूप में # (...) सिंटैक्स का उपयोग करता है। आप अपने कोड में शाब्दिक वैक्टर बनाने और शामिल करने के लिए इस (...) सिंटैक्स का उपयोग कर सकते हैं।

हालाँकि, ये शाब्दिक वैक्टर हैं, इसलिए इन्हें संशोधित करना LISP में परिभाषित नहीं है। इसलिए, प्रोग्रामिंग के लिए, आपको हमेशा उपयोग करना चाहिएvector फ़ंक्शन, या अधिक सामान्य फ़ंक्शन make-array वैक्टर बनाने के लिए आप संशोधित करने की योजना बनाते हैं।

make-arrayवेक्टर बनाने के लिए फ़ंक्शन अधिक सामान्य तरीका है। आप वेक्टर तत्वों का उपयोग कर सकते हैंaref समारोह।

उदाहरण 2

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

(setq a (make-array 5 :initial-element 0))
(setq b (make-array 5 :initial-element 2))

(dotimes (i 5)
   (setf (aref a i) i))
   
(write a)
(terpri)
(write b)
(terpri)

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

#(0 1 2 3 4)
#(2 2 2 2 2)

पॉइंटर भरें

make-array फ़ंक्शन आपको एक resizable वेक्टर बनाने की अनुमति देता है।

fill-pointerफ़ंक्शन का तर्क वेक्टर में वास्तव में संग्रहीत तत्वों की संख्या का ट्रैक रखता है। जब आप वेक्टर में कोई तत्व जोड़ते हैं तो यह अगली स्थिति का सूचकांक होता है।

vector-pushफ़ंक्शन आपको एक resizable वेक्टर के अंत में एक तत्व जोड़ने की अनुमति देता है। यह भरण-सूचक को 1 से बढ़ाता है।

vector-pop फ़ंक्शन सबसे हाल ही में धकेल दिया आइटम लौटाता है और 1 से भरने वाले सूचक को घटाता है।

उदाहरण

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

(setq a (make-array 5 :fill-pointer 0))
(write a)

(vector-push 'a a)
(vector-push 'b a)
(vector-push 'c a)

(terpri)
(write a)
(terpri)

(vector-push 'd a)
(vector-push 'e a)

;this will not be entered as the vector limit is 5
(vector-push 'f a)

(write a)
(terpri)

(vector-pop a)
(vector-pop a)
(vector-pop a)

(write a)

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

#()
#(A B C)
#(A B C D E)
#(A B)

वैक्टर अनुक्रम हो रहा है, सभी अनुक्रम कार्य वैक्टर के लिए लागू होते हैं। सदिश कार्यों के लिए कृपया अनुक्रम अध्याय से परामर्श करें।