Graphs এবং Complex Data Structures

Data Structures in Haskell (ডেটা স্ট্রাকচার) - হ্যাস্কেল (Haskell) - Computer Programming

299

Haskell এ Graphs এবং Complex Data Structures

Haskell একটি ফাংশনাল প্রোগ্রামিং ভাষা, যা immutable এবং highly expressive ডেটা স্ট্রাকচার নিয়ে কাজ করতে সক্ষম। Graphs এবং Complex Data Structures (যেমন ট্রি, হ্যাশ টেবিল, গ্রাফ, স্ট্যাক, কিউ, ইত্যাদি) Haskell এ প্রায়ই ব্যবহৃত হয় এবং এগুলি তৈরি করতে Haskell এর শক্তিশালী টাইপ সিস্টেম এবং উচ্চ স্তরের ফাংশনাল প্রোগ্রামিং ধারণাগুলি ব্যবহৃত হয়।

এখানে আমরা Graphs এবং Complex Data Structures নিয়ে আলোচনা করবো এবং এগুলোর বাস্তবায়ন দেখাবো।


1. Graphs in Haskell

একটি Graph হলো ডেটার একটি সংগ্রহ, যেখানে Nodes (vertices) এবং Edges (যোগাযোগ) থাকে। Haskell এ গ্রাফের প্রতিনিধিত্ব করার জন্য বিভিন্ন পদ্ধতি ব্যবহার করা যায়, তবে এখানে আমরা সাধারণত adjacency list বা adjacency matrix ব্যবহার করবো।

1.1. Adjacency List Representation

গ্রাফের একটি সাধারণ উপস্থাপন হলো adjacency list। একটি গ্রাফের প্রতিটি নোডের জন্য একটি লিস্ট থাকে যা তার সাথে সংযুক্ত অন্য নোডগুলিকে ধারণ করে।

ধরা যাক, একটি গ্রাফে তিনটি নোড এবং তাদের মধ্যে কিছু সম্পর্ক রয়েছে।

  • নোড 1, নোড 2 এবং নোড 3।
  • নোড 1 এবং নোড 2 সংযুক্ত।
  • নোড 2 এবং নোড 3 সংযুক্ত।

এটি adjacency list দ্বারা নিম্নরূপ প্রকাশ করা যেতে পারে:

type Graph = [(Int, [Int])]

এখানে Int হলো নোড, এবং [Int] হলো নোডের সাথে সংযুক্ত অন্যান্য নোডের লিস্ট।

graph :: Graph
graph = [(1, [2]), (2, [1, 3]), (3, [2])]

এখানে, graph হল একটি গ্রাফ, যেখানে:

  • নোড 1 এর সাথে নোড 2 সংযুক্ত,
  • নোড 2 এর সাথে নোড 1 এবং 3 সংযুক্ত,
  • নোড 3 এর সাথে নোড 2 সংযুক্ত।

1.2. Graph Traversal

গ্রাফে Depth First Search (DFS) এবং Breadth First Search (BFS) এর মতো ট্র্যাভার্সাল (পর্যবেক্ষণ) এলগরিদম চালানো যেতে পারে।

DFS উদাহরণ:

dfs :: Graph -> Int -> [Int]
dfs graph start = dfs' graph [start] []

dfs' :: Graph -> [Int] -> [Int] -> [Int]
dfs' _ [] visited = visited
dfs' graph (x:xs) visited
  | x `elem` visited = dfs' graph xs visited
  | otherwise = dfs' graph (neighbors graph x ++ xs) (x:visited)

neighbors :: Graph -> Int -> [Int]
neighbors graph node = case lookup node graph of
    Just ns -> ns
    Nothing -> []

এখানে dfs ফাংশন গ্রাফের একটি ডিপথ ফার্স্ট সার্চ (DFS) চালায়।


2. Complex Data Structures in Haskell

Haskell এর মধ্যে বিভিন্ন ধরনের Complex Data Structures তৈরি এবং ব্যবহার করা হয়, যা ডেটা সংগঠিত করার জন্য শক্তিশালী উপায় প্রদান করে।

2.1. Trees

একটি Tree হলো এমন একটি ডেটা স্ট্রাকচার, যেখানে একটি রুট নোড থাকে এবং প্রতিটি নোডের মধ্যে এক বা একাধিক সন্তান নোড থাকে। একটি সাধারণ বাইনারি ট্রি (যে ট্রিতে প্রতিটি নোডে সর্বোচ্চ দুটি সন্তান থাকে) নিম্নরূপ সংজ্ঞায়িত করা যায়:

data Tree a = Empty | Node a (Tree a) (Tree a)

এখানে, Tree একটি ফাংশনাল ডেটা টাইপ, যার মধ্যে দুটি কনস্ট্রাক্টর রয়েছে:

  • Empty: একটি খালি গাছ,
  • Node: একটি নোড, যা একটি মান ধারণ করে এবং দুটি সন্তানের সাথে যুক্ত থাকে।

উদাহরণ:

tree :: Tree Int
tree = Node 1 (Node 2 Empty Empty) (Node 3 Empty Empty)

এখানে tree একটি বাইনারি ট্রি যা নিচের গঠন ধারণ করে:

    1
   / \
  2   3

2.2. Stacks (LIFO)

Stack হলো একটি LIFO (Last In, First Out) ডেটা স্ট্রাকচার, যেখানে সর্বশেষ যে আইটেমটি যুক্ত হয়, সেটিই প্রথমে মুছে ফেলা হয়।

data Stack a = Stack [a]

এখানে Stack একটি লিস্টের মধ্যে ডেটা ধারণ করে। ফাংশনগুলো দিয়ে আমরা স্ট্যাকের উপরে ডেটা যোগ বা মুছে ফেলতে পারি।

উদাহরণ:

push :: a -> Stack a -> Stack a
push x (Stack xs) = Stack (x:xs)

pop :: Stack a -> (a, Stack a)
pop (Stack (x:xs)) = (x, Stack xs)

top :: Stack a -> a
top (Stack (x:_)) = x

2.3. Queues (FIFO)

Queue হলো একটি FIFO (First In, First Out) ডেটা স্ট্রাকচার, যেখানে প্রথমে যুক্ত হওয়া আইটেমটি প্রথমে মুছে ফেলা হয়।

data Queue a = Queue [a] [a]

এখানে, Queue দুটি লিস্ট ধারণ করে: একটি ইনপুট লিস্ট এবং একটি আউটপুট লিস্ট।

উদাহরণ:

enqueue :: a -> Queue a -> Queue a
enqueue x (Queue inQueue outQueue) = Queue (x:inQueue) outQueue

dequeue :: Queue a -> (a, Queue a)
dequeue (Queue [] []) = error "Queue is empty"
dequeue (Queue inQueue (x:outQueue)) = (x, Queue inQueue outQueue)
dequeue (Queue inQueue []) = dequeue (Queue [] (reverse inQueue))

3. Other Complex Data Structures

3.1. Hash Maps

Haskell এ Hash Maps তৈরি করতে Data.Map মডিউল ব্যবহার করা হয়। এই ডেটা স্ট্রাকচারটি কী এবং মানের সম্পর্ক তৈরি করতে ব্যবহৃত হয়।

import qualified Data.Map as Map

myMap :: Map.Map String Int
myMap = Map.fromList [("a", 1), ("b", 2), ("c", 3)]

3.2. Sets

Sets হলো একটি ডেটা স্ট্রাকচার যা একক মানের একটি集合 ধারণ করে, যেখানে একই মান দুইবার থাকতে পারে না। এটি Data.Set মডিউল ব্যবহার করে তৈরি করা যায়।

import qualified Data.Set as Set

mySet :: Set.Set Int
mySet = Set.fromList [1, 2, 3, 4]

উপসংহার

Haskell এ Graphs এবং Complex Data Structures ব্যবহারের মাধ্যমে কোডের মডুলারিটি, কর্মক্ষমতা এবং পুনঃব্যবহারযোগ্যতা বাড়ানো যায়। Graphs এর মধ্যে বিভিন্ন ধরনের ডেটা সংরক্ষণ এবং সম্পর্ক স্থাপন করা যায়, এবং Complex Data Structures যেমন Trees, Stacks, Queues, Hash Maps, এবং Sets ডেটাকে আরও কার্যকরীভাবে সংগঠিত করতে সাহায্য করে। Haskell এর শক্তিশালী টাইপ সিস্টেম এবং ফাংশনাল প্রোগ্রামিং ধারণাগুলি এই ডেটা স্ট্রাকচারগুলিকে সহজে পরিচালনা করতে সহায়ক।

Content added By
Promotion

Are you sure to start over?

Loading...