हास्केल - कार्यों पर अधिक
अब तक, हमने कई प्रकार के हास्केल फ़ंक्शन पर चर्चा की है और उन कार्यों को कॉल करने के लिए विभिन्न तरीकों का उपयोग किया है। इस अध्याय में, हम कुछ बुनियादी कार्यों के बारे में जानेंगे जिन्हें किसी विशेष प्रकार के वर्ग को आयात किए बिना हास्केल में आसानी से उपयोग किया जा सकता है। इन कार्यों में से अधिकांश अन्य उच्च आदेश कार्यों का एक हिस्सा हैं।
हेड फंक्शन
Headएक सूची पर कार्य करता है। यह इनपुट तर्क का पहला रिटर्न देता है जो मूल रूप से एक सूची है। निम्नलिखित उदाहरण में, हम 10 मानों के साथ एक सूची पारित कर रहे हैं और हम उस सूची के पहले तत्व को उत्पन्न कर रहे हैंhead समारोह।
main = do
let x = [1..10]
putStrLn "Our list is:"
print (x)
putStrLn "The first element of the list is:"
print (head x)
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
Our list is:
[1,2,3,4,5,6,7,8,9,10]
The first element of the list is:
1
टेल फ़ंक्शन
Tail समारोह है कि पूरक है headसमारोह। यह एक लेता हैlistइनपुट के रूप में और सिर के हिस्से के बिना पूरी सूची देता है। इसका मतलब है,tailफ़ंक्शन पहले तत्व के बिना पूरी सूची देता है। निम्नलिखित उदाहरण पर एक नज़र डालें -
main = do
let x = [1..10]
putStrLn "Our list is:"
print (x)
putStrLn "The tail of our list is:"
print (tail x)
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
Our list is:
[1,2,3,4,5,6,7,8,9,10]
The tail of our list is:
[2,3,4,5,6,7,8,9,10]
अंतिम कार्य
जैसा कि नाम से पता चलता है, यह इनपुट के रूप में प्रदान की जाने वाली सूची के अंतिम तत्व की पैदावार करता है। निम्नलिखित उदाहरण की जाँच करें।
main = do
let x = [1..10]
putStrLn "Our list is:"
print (x)
putStrLn "The last element of our list is:"
print (last x)
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
Our list is:
[1,2,3,4,5,6,7,8,9,10]
The last element of our list is:
10
Init फ़ंक्शन
Init इसके ठीक विपरीत काम करता है tailसमारोह। यह एक तर्क के रूप में एक सूची लेता है और अंतिम प्रविष्टि के बिना पूरी सूची देता है।
main = do
let x = [1..10]
putStrLn "Our list is:"
print (x)
putStrLn "Our list without the last entry:"
print (init x)
अब, इसके उत्पादन का निरीक्षण करें -
Our list is:
[1,2,3,4,5,6,7,8,9,10]
Our list without the last entry:
[1,2,3,4,5,6,7,8,9]
अशक्त क्रिया
Null एक बूलियन चेक फ़ंक्शन है जो स्ट्रिंग और रिटर्न पर काम करता है True केवल जब दी गई सूची खाली है, अन्यथा यह वापस आ जाती है False। निम्न कोड की जाँच करता है कि आपूर्ति की गई सूची खाली है या नहीं।
main = do
let x = [1..10]
putStrLn "Our list is:"
print (x)
putStrLn "Is our list empty?"
print (null x)
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
Our list is:
[1,2,3,4,5,6,7,8,9,10]
Is our list empty?
False
उलटा कार्य
यह एक स्ट्रिंग इनपुट पर काम करता है और पूरे इनपुट को रिवर्स ऑर्डर में परिवर्तित करता है और परिणामस्वरूप एक आउटपुट देता है। नीचे इस फ़ंक्शन का कोड आधार है।
main = do
let x = [1..10]
putStrLn "Our list is:"
print (x)
putStrLn "The list in Reverse Order is:"
print (reverse x)
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
Our list is:
[1,2,3,4,5,6,7,8,9,10]
The list in Reverse Order is:
[10,9,8,7,6,5,4,3,2,1]
लंबाई समारोह
इस फ़ंक्शन का उपयोग लंबाई की गणना करने के लिए किया जाता है listएक तर्क के रूप में दिया। निम्नलिखित उदाहरण पर एक नज़र डालें -
main = do
let x = [1..10]
putStrLn "Our list is:"
print (x)
putStrLn "The length of this list is:"
print (length x)
हमारी सूची में 10 तत्व हैं, इसलिए हमारा कोड आउटपुट के रूप में 10 का उत्पादन करेगा।
Our list is:
[1,2,3,4,5,6,7,8,9,10]
The length of this list is:
10
फंक्शन लो
Takeफ़ंक्शन का उपयोग किसी अन्य स्ट्रिंग से उप-स्ट्रिंग बनाने के लिए किया जाता है। निम्न कोड दिखाता है कि आप हास्केल में टेक फ़ंक्शन का उपयोग कैसे कर सकते हैं -
main = print(take 5 ([1 .. 10]))
कोड एक उप-स्ट्रिंग प्रदान करता है जिसमें आपूर्ति की गई सूची से 5 तत्व होते हैं -
[1,2,3,4,5]
ड्रॉप फंक्शन
इस फ़ंक्शन का उपयोग उप-स्ट्रिंग उत्पन्न करने के लिए भी किया जाता है। यह इसके विपरीत के रूप में कार्य करता हैtakeसमारोह। निम्नलिखित कोड को देखें -
main = print(drop 5 ([1 .. 10]))
कोड आपूर्ति सूची से पहले 5 तत्वों को छोड़ देता है और शेष 5 तत्वों को प्रिंट करता है। यह निम्नलिखित उत्पादन का उत्पादन करेगा -
[6,7,8,9,10]
अधिकतम कार्य
इस फ़ंक्शन का उपयोग आपूर्ति की गई सूची से अधिकतम मूल्य वाले तत्व को खोजने के लिए किया जाता है। आइए देखते हैं कि इसे व्यवहार में कैसे उपयोग किया जाए -
main = do
let x = [1,45,565,1245,02,2]
putStrLn "The maximum value element of the list is:"
print (maximum x)
कोड का उपरोक्त टुकड़ा निम्नलिखित उत्पादन उत्पन्न करेगा -
The maximum value element of the list is:
1245
न्यूनतम कार्य
इस फ़ंक्शन का उपयोग आपूर्ति की गई सूची से न्यूनतम मूल्य के साथ तत्व को खोजने के लिए किया जाता है। यह इसके ठीक विपरीत हैmaximum समारोह।
main = do
let x = [1,45,565,1245,02,2]
putStrLn "The minimum value element of the list is:"
print (minimum x)
उपरोक्त कोड का आउटपुट है -
The minimum value element of the list is:
1
सम फलन
जैसा कि नाम से पता चलता है, यह फ़ंक्शन आपूर्ति की गई सूची में मौजूद सभी तत्वों का योग देता है। निम्न कोड 5 तत्वों की एक सूची लेता है और आउटपुट के रूप में उनके योग देता है।
main = do
let x = [1..5]
putStrLn "Our list is:"
print (x)
putStrLn "The summation of the list elements is:"
print (sum x)
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
Our list is:
[1,2,3,4,5]
The summation of the list elements is:
15
उत्पाद समारोह
आप इस फ़ंक्शन का उपयोग किसी सूची के सभी तत्वों को गुणा करने और इसके मूल्य को प्रिंट करने के लिए कर सकते हैं।
main = do
let x = [1..5]
putStrLn "Our list is:"
print (x)
putStrLn "The multiplication of the list elements is:"
print (product x)
हमारा कोड निम्न आउटपुट का उत्पादन करेगा -
Our list is:
[1,2,3,4,5]
The multiplication of the list elements is:
120
एलिफेंट फंक्शन
इस फ़ंक्शन का उपयोग यह जांचने के लिए किया जाता है कि आपूर्ति की गई सूची में एक विशिष्ट तत्व है या नहीं। तदनुसार, यह या तो रिटर्न करता हैtrue या ए false।
निम्न कोड यह जांचता है कि तत्वों की आपूर्ति की गई सूची में मूल्य 786 है या नहीं।
main = do
let x = [1,45,155,1785]
putStrLn "Our list is:"
print (x)
putStrLn "Does it contain 786?"
print (elem 786 (x))
यह निम्नलिखित उत्पादन का उत्पादन करेगा -
Our list is:
[1,45,155,1785]
Does it contain 786?
False
जाँच करने के लिए समान कोड का उपयोग करें कि आपूर्ति की गई सूची में मूल्य 1785 है या नहीं।