Haskell - Fermuarlar

Zippers Haskell'de temelde veri yapısının belirli bir konumuna işaret eden işaretçiler vardır. tree.

Bir düşünelim tree 5 elemente sahip [45,7,55,120,56]mükemmel bir ikili ağaç olarak gösterilebilir. Bu listenin son öğesini güncellemek istersem, onu güncellemeden önce son öğeye ulaşmak için tüm öğeleri geçmem gerekir. Sağ?

Ama ya ağacımızı bir sahip olma ağacının N öğeler bir koleksiyondur [(N-1),N]. O halde, tüm istenmeyen şeylerden geçmemiz gerekmez(N-1)elementler. Doğrudan N. elementi güncelleyebiliriz. Bu tam olarak Fermuar kavramıdır. Ağacın tamamını dolaşmadan bu değeri güncelleyebileceğimiz bir ağacın belirli bir konumuna odaklanır veya işaret eder.

Aşağıdaki örnekte, bir Listede Fermuar kavramını uyguladık. Aynı şekilde, Fermuar'ı birtree veya a file veri yapısı.

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]))

Yukarıdaki programı derleyip çalıştırdığınızda, aşağıdaki çıktıyı üretecektir -

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

Burada, ileri giderken veya geri giderken tüm dizginin bir öğesine odaklanıyoruz.