एल्म - सूची

मूल्यों के संग्रह को संग्रहीत करने के लिए सूची, टुपल्स और रिकॉर्ड डेटा संरचनाओं का उपयोग किया जा सकता है।

इस अध्याय में चर्चा की गई है कि एल्म में सूची का उपयोग कैसे किया जाए।

एक सूची सजातीय मूल्यों का एक संग्रह है। किसी सूची के मान सभी एक ही डेटा प्रकार के होने चाहिए।

मूल्यों को संग्रहीत करने के लिए चर का उपयोग करते समय निम्नलिखित सीमाओं पर विचार करें -

  • चर प्रकृति में स्केलर हैं। दूसरे शब्दों में, घोषणा के समय एक चर केवल एक मूल्य पकड़ सकता है। इसका मतलब है कि एक प्रोग्राम में एन वैल्यूज़ को स्टोर करने के लिए एन वेरिएबल डिक्लेरेशन की ज़रूरत होगी। इसलिए, जब मूल्यों का एक बड़ा संग्रह संग्रहीत करने की आवश्यकता होती है, तो चर का उपयोग संभव नहीं होता है।

  • एक कार्यक्रम में चर को यादृच्छिक क्रम में मेमोरी आवंटित की जाती है, जिससे उनकी घोषणा के क्रम में मूल्यों को पुनः प्राप्त / पढ़ना मुश्किल हो जाता है।

वाक्य - विन्यास

List_name = [value1,value2,value3.....valuen]

चित्रण

निम्न उदाहरण दिखाता है कि एल्म में एक सूची का उपयोग कैसे करें। इस उदाहरण को एल्म REPL में आज़माएं -

> myList1 = [10,20,30]
[10,20,30] : List number
> myList2 = ["hello","world"]
["hello","world"] : List String

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

> myList = [1,"hello"]
-- TYPE MISMATCH 
--------------------------------------------- 
repl-temp-000.elm

The 1st and 2nd entries in this list are different types of values.

4| [1,"hello"]
^^^^^^^
The 1st entry has this type:
   number
But the 2nd is:
   String

सूची संचालन

निम्न तालिका सूची पर आम संचालन दिखाती है -

अनु क्रमांक तरीका विवरण
1 isEmpty: सूची a -> बूल यदि सूची खाली है तो जाँच करें
2 रिवर्स: लिस्ट ए -> बूल इनपुट सूची को उलट देता है
3 लंबाई: सूची -> इंट सूची का आकार लौटाता है
4 अधिकतम: सूची तुलनीय -> हो सकता है। तुलना योग्य अधिकतम मूल्य देता है
5 न्यूनतम: सूची तुलनीय -> हो सकता है। तुलना योग्य न्यूनतम मूल्य देता है
6 योग: सूची संख्या -> संख्या सूची में सभी तत्वों का योग
7 उत्पाद: सूची संख्या -> संख्या यदि सूची खाली है तो जाँच करें
8 सॉर्ट: सूची तुलनीय -> सूची तुलनीय क्रम में आरोही क्रम में सूची
9 concat: सूची (सूची) -> सूची a सूची के एक समूह को एक में मिला देता है
10 append: a -> लिस्ट a -> लिस्ट a एक साथ दो सूचियों को मिलाता है
1 1 रेंज: इंट -> इंट -> सूची इंट शुरू से अंत तक संख्याओं की एक सूची देता है
12 फ़िल्टर: (a -> बूल) -> सूची a -> सूची a इनपुट सूची से मानों की सूची फ़िल्टर करता है
13 प्रमुख: सूची a -> हो सकता है सूची से पहला तत्व देता है
14 पूंछ:: एक -> शायद। सूची (सूची एक) सिर को छोड़कर सभी तत्वों को लौटाता है

खाली है

यदि कोई सूची खाली है, तो यह फ़ंक्शन सही है।

वाक्य - विन्यास

List.isEmpty list_name

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.isEmpty
<function> : List a -> Bool

चित्रण

> List.isEmpty
<function> : List a -> Bool

> List.isEmpty [10,20,30]
False : Bool

उलटना

यह फ़ंक्शन सूची को उलट देता है।

वाक्य - विन्यास

List.reverse list_name

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.reverse
<function> : List a -> List a

चित्रण

> List.reverse [10,20,30]
[30,20,10] : List number

लंबाई

यह फ़ंक्शन किसी सूची की लंबाई लौटाता है।

वाक्य - विन्यास

List.length list_name

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.length
<function> : List a -> Int

चित्रण

> List.length [10,20,30]
3 : Int

ज्यादा से ज्यादा

यह फ़ंक्शन गैर-रिक्त सूची में अधिकतम तत्व देता है।

वाक्य - विन्यास

List.maximum list_name

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.maximum
<function> : List comparable -> Maybe.Maybe comparable

चित्रण

> List.maximum [10,20,30]
Just 30 : Maybe.Maybe number
> List.maximum []
Nothing : Maybe.Maybe comparable

न्यूनतम

यह फ़ंक्शन गैर-रिक्त सूची में न्यूनतम तत्व देता है।

वाक्य - विन्यास

List.minimum list_name

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.minimum
<function> : List comparable -> Maybe.Maybe comparable

चित्रण

> List.minimum [10,20,30]
Just 10 : Maybe.Maybe number

योग

यह फ़ंक्शन किसी सूची में सभी तत्वों का योग लौटाता है।

वाक्य - विन्यास

List.sum list_name

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.sum
<function> : List number -> number

चित्रण

> List.sum [10,20,30]
60 : number

उत्पाद

यह फ़ंक्शन किसी सूची में सभी तत्वों के उत्पाद को लौटाता है।

वाक्य - विन्यास

List.product list_name

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

<function>  : List number ->  number

चित्रण

List.product [10,20,30]
6000 : number

तरह

यह फ़ंक्शन किसी सूची में निम्नतम से लेकर उच्चतम तक मानों को सॉर्ट करता है।

वाक्य - विन्यास

List.sort list_name

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.sort
<function> : List comparable -> List comparable

चित्रण

> List.sort [10,20,30]
[10,20,30] : List number

concat

यह फ़ंक्शन किसी एकल सूची में सूचियों के एक समूह को सम्मिलित करता है।

वाक्य - विन्यास

List.concat [ [list_name1],[list_name2],[list_name3],.....[list_nameN] ]

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.concat
<function> : List (List a) -> List a

चित्रण

> List.concat [[10,20], [30,40],[50,60]]
[10,20,30,40,50,60] : List number

संलग्न

यह फ़ंक्शन दो सूचियों को एक साथ रखता है।

वाक्य - विन्यास

List.append [list_name1] [list_name2]

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.append
<function> : List a -> List a -> List a

चित्रण

> List.append [10,20] [30,40]
[10,20,30,40] : List number

++ ऑपरेटर का उपयोग किसी सूची को दूसरे में जोड़ने के लिए भी किया जा सकता है। यह नीचे दिए गए उदाहरण में दिखाया गया है -

> [10.1,20.2] ++ [30.3,40.4]
[10.1,20.2,30.3,40.4] : List Float

रेंज

यह फ़ंक्शन संख्याओं की सूची बनाता है, प्रत्येक तत्व एक से बढ़ रहा है। सबसे कम और सबसे अधिक संख्या जो सूची में होनी चाहिए, फ़ंक्शन को पास की जाती है।

वाक्य - विन्यास

List.range start_range end_range

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.range
<function> : Int -> Int -> List Int

चित्रण

> List.range 1 10
[1,2,3,4,5,6,7,8,9,10] : List Int

फिल्टर

यह फ़ंक्शन इनपुट सूची से मानों के एक सेट को फ़िल्टर करता है। केवल वही मान रखें जो परीक्षा पास करते हैं।

वाक्य - विन्यास

List.filter test_function input_list

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.filter
<function> : (a -> Bool) -> List a -> List a

चित्रण

निम्नलिखित उदाहरण एक इनपुट सूची से सभी संख्याओं को फ़िल्टर करता है

> List.filter (\n -> n%2==0) [10,20,30,55]
[10,20,30] : List Int

सिर

यह फ़ंक्शन इनपुट सूची से पहला तत्व देता है।

वाक्य - विन्यास

List.head input_list

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.head
<function> : List a -> Maybe.Maybe a

चित्रण

> List.head [10,20,30,40]
Just 10 : Maybe.Maybe number
> List.head []
Nothing : Maybe.Maybe a

पूंछ

यह फ़ंक्शन सूची में पहले के बाद सभी तत्वों को लौटाता है।

वाक्य - विन्यास

List.tail input_list

फ़ंक्शन के हस्ताक्षर की जांच करने के लिए, एल्म आरईपीएल में निम्नलिखित लिखें -

> List.tail
<function> : List a -> Maybe.Maybe (List a)

चित्रण

> List.tail [10,20,30,40,50]
Just [20,30,40,50] : Maybe.Maybe (List number)
> List.tail [10]
Just [] : Maybe.Maybe (List number)
> List.tail []
Nothing : Maybe.Maybe (List a)

विपक्ष ऑपरेटर का उपयोग करना

बुरा ऑपरेटर (::) एक सूची के सामने एक तत्व जोड़ता है।

चित्रण

> 10::[20,30,40,50]
[10,20,30,40,50] : List number

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

> [1,2,3,4]::[5,6,7,8]
-- TYPE MISMATCH ---------------------------------
------------ repl-temp-000.elm

The right side of (::) is causing a type mismatch.

3| [1,2,3,4]::[5,6,7,8]
			  ^^^^^^^^^
(::) is expecting the right side to be a:

   List (List number)

But the right side is:

   List number
Hint: With operators like (::) I always check the left side first. If it seems fine, 
I assume it is correct and check the right side. So the 
problem may be in how the left and right arguments interact.

सूचियाँ अपरिवर्तनीय हैं

आइए देखें कि क्या एल्म में सूचियां अपरिवर्तनीय हैं। पहली सूची myList जब मान 1 के साथ सम्‍मिलित एक नई सूची बनाता है और myListCopy पर वापस आ जाता है । इसलिए, यदि हम प्रारंभिक सूची प्रदर्शित करते हैं, तो इसके मान नहीं बदले जाएंगे।

> myList = [10,20,30]
[10,20,30] : List number
> myListCopy = 1::myList
[1,10,20,30] : List number
> myList
[10,20,30] : List number
>myList == myListCopy
False : Bool