हास्केल - जिपर्स

Zippers हास्केल मूल रूप से संकेत हैं जो डेटा संरचना के कुछ विशिष्ट स्थान को इंगित करते हैं जैसे कि ए tree

आइए हम विचार करें tree 5 तत्वों वाले [45,7,55,120,56]जिसे एक आदर्श बाइनरी ट्री के रूप में दर्शाया जा सकता है। अगर मैं इस सूची के अंतिम तत्व को अपडेट करना चाहता हूं, तो मुझे इसे अपडेट करने से पहले अंतिम तत्व तक पहुंचने के लिए सभी तत्वों के माध्यम से पार करना होगा। सही?

लेकिन, क्या होगा अगर हम अपने पेड़ का निर्माण इस तरह से कर सकते हैं जैसे कि एक पेड़ N तत्वों का एक संग्रह है [(N-1),N]। फिर, हम सभी अवांछित के माध्यम से नहीं की जरूरत है(N-1)तत्वों। हम सीधे Nth तत्व को अपडेट कर सकते हैं। यह बिल्कुल जिपर की अवधारणा है। यह एक पेड़ के एक विशिष्ट स्थान पर ध्यान केंद्रित करता है या इंगित करता है जहां हम पूरे पेड़ को पीछे किए बिना उस मूल्य को अपडेट कर सकते हैं।

निम्नलिखित उदाहरण में, हमने एक सूची में जिपर की अवधारणा को लागू किया है। उसी तरह, एक में जिपर लागू कर सकते हैंtree या ए file डेटा संरचना।

data List a = Empty | Cons a (List a) deriving (Show, Read, Eq, Ord)
type Zipper_List a = ([a],[a])    

go_Forward :: Zipper_List a -> Zipper_List a   
go_Forward (x:xs, bs) = (xs, x:bs)   
   
go_Back :: Zipper_List a -> Zipper_List a   
go_Back (xs, b:bs) = (b:xs, bs)    

main = do 
   let list_Ex = [1,2,3,4] 
   print(go_Forward (list_Ex,[]))       
   print(go_Back([4],[3,2,1]))

जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -

([2,3,4],[1]) 
([3,4],[2,1])

यहां हम आगे जाते समय या पीछे की ओर आते हुए पूरे स्ट्रिंग के एक तत्व पर ध्यान केंद्रित कर रहे हैं।