Lists এবং Tuples (লিস্ট এবং টুপল)

হ্যাস্কেল (Haskell) - Computer Programming

460

Lists and Tuples in Haskell (লিস্ট এবং টুপল)

Haskell এ লিস্ট এবং টুপল দুটি অত্যন্ত গুরুত্বপূর্ণ এবং সাধারণ ডেটা স্ট্রাকচার। এগুলি বিভিন্ন ধরণের ডেটা সংগ্রহে ব্যবহৃত হয় এবং বিভিন্ন কাজের জন্য উপযোগী। Haskell এ লিস্ট এবং টুপল এর ব্যবহার এবং বৈশিষ্ট্য নিয়ে আলোচনা করা হলো।


১. লিস্ট (Lists)

Haskell এ লিস্ট এমন একটি ডেটা স্ট্রাকচার যা একধরণের একাধিক মান ধারণ করতে পারে। লিস্টে একই ধরনের ডেটা থাকতে হয়, এবং এটি একটি অর্ডারড (ordered) কালেকশন, অর্থাৎ মানগুলোর মধ্যে একটি নির্দিষ্ট ক্রম থাকে।

১.১. লিস্ট ডিফাইনেশন

লিস্ট ডিফাইন করতে, আপনি সাধারণত নিম্নলিখিত সিনট্যাক্স ব্যবহার করবেন:

numbers = [1, 2, 3, 4, 5]

এখানে:

  • numbers একটি লিস্ট যা পূর্ণসংখ্যা ধারণ করে: [1, 2, 3, 4, 5]

১.২. লিস্টের অপারেশনস

Haskell এ লিস্টের সাথে অনেক ধরনের অপারেশন করা যায়:

  • head: লিস্টের প্রথম উপাদান।
  • tail: প্রথম উপাদান বাদে বাকি উপাদানগুলো।
  • length: লিস্টের দৈর্ঘ্য।
  • sum: লিস্টের সব উপাদানের যোগফল।
head numbers   -- 1
tail numbers   -- [2, 3, 4, 5]
length numbers -- 5
sum numbers    -- 15

১.৩. লিস্ট কনস (List Cons)

লিস্টে নতুন উপাদান যোগ করার জন্য : চিহ্ন ব্যবহার করা হয়:

newList = 0 : numbers

এখানে:

  • 0 : numbers মানে 0 উপাদানটি numbers লিস্টের শুরুতে যোগ করা হয়েছে, ফলে নতুন লিস্ট হবে [0, 1, 2, 3, 4, 5]

১.৪. লিস্ট কম্প্রিহেনশন (List Comprehension)

লিস্ট কম্প্রিহেনশন একটি শক্তিশালী কৌশল যা লিস্ট তৈরি করতে ব্যবহৃত হয়:

squares = [x * x | x <- [1..5]]

এখানে:

  • [x * x | x <- [1..5]] একটি লিস্ট কম্প্রিহেনশন যা ১ থেকে ৫ পর্যন্ত সংখ্যাগুলির বর্গফল তৈরি করবে, ফলস্বরূপ লিস্ট হবে [1, 4, 9, 16, 25]

১.৫. নেস্টেড লিস্ট (Nested Lists)

Haskell এ লিস্টের মধ্যে লিস্ট থাকতে পারে (nested lists):

nestedList = [[1, 2], [3, 4], [5, 6]]

এখানে:

  • nestedList একটি লিস্ট যার মধ্যে তিনটি লিস্ট আছে: [[1, 2], [3, 4], [5, 6]]

২. টুপল (Tuples)

Haskell এ টুপল এমন একটি ডেটা স্ট্রাকচার যা বিভিন্ন ধরনের মান একসাথে ধারণ করতে পারে। একটি টুপল বিভিন্ন টাইপের উপাদান ধারণ করতে পারে, অর্থাৎ এটি হেটারোজেনিয়াস (heterogeneous) ডেটা ধারণ করে। টুপল সাধারণত একটি ফিক্সড সাইজ স্ট্রাকচার, অর্থাৎ একটি টুপলের আকার নির্দিষ্ট থাকে এবং পরবর্তীতে তা পরিবর্তন করা যায় না।

২.১. টুপল ডিফাইনেশন

টুপল ডিফাইন করতে, আপনি সাধারণত নীচের মতো সিনট্যাক্স ব্যবহার করবেন:

person = ("John", 30)

এখানে:

  • person একটি টুপল যা দুটি মান ধারণ করে: একটি String (নাম) এবং একটি Int (বয়স)।

২.২. টুপল এর উপাদান অ্যাক্সেস (Accessing Tuple Elements)

টুপলের মান অ্যাক্সেস করতে fst এবং snd ফাংশন ব্যবহার করা হয়:

  • fst: প্রথম উপাদান প্রদান করে।
  • snd: দ্বিতীয় উপাদান প্রদান করে।
fst person -- "John"
snd person -- 30

২.৩. বড় টুপল (Large Tuples)

Haskell এ আপনি আরও বড় টুপলও তৈরি করতে পারেন, যেখানে আরও বেশি উপাদান থাকতে পারে। উদাহরণস্বরূপ, একটি ৩-এলিমেন্টের টুপল:

coordinates = (10.5, 20.3, 30.8)

এখানে:

  • coordinates একটি টুপল যা তিনটি মান ধারণ করে: Float টাইপের তিনটি উপাদান।

২.৪. টুপলস এর বৈশিষ্ট্য

  • অর্ডারড: টুপলগুলিতে উপাদানগুলির একটি নির্দিষ্ট ক্রম থাকে।
  • ফিক্সড সাইজ: একবার টুপল তৈরি হলে, তার আকার পরিবর্তন করা যায় না।
  • হেটারোজেনিয়াস: টুপলগুলির বিভিন্ন ধরনের ডেটা ধারণ করতে পারে (যেমন, একে একে String, Int, Float ইত্যাদি)।

৩. লিস্ট বনাম টুপল (List vs Tuple)

বৈশিষ্ট্যলিস্ট (List)টুপল (Tuple)
আকারডাইনামিক (Dynamic)ফিক্সড (Fixed)
টাইপসমস্ত উপাদান একই টাইপ হতে হবেবিভিন্ন টাইপের উপাদান থাকতে পারে
ইনডেক্সিংলিস্টের মধ্যে ইনডেক্সিং সম্ভবইনডেক্সিং নেই, তবে প্যাটার্ন ম্যাচিং ব্যবহার করা যায়
ব্যবহারসাধারণত একই টাইপের ডেটা রাখাবিভিন্ন টাইপের ডেটা রাখার জন্য ব্যবহৃত

উপসংহার

লিস্ট এবং টুপল Haskell এ দুটি মৌলিক ডেটা স্ট্রাকচার। লিস্ট একধরণের একাধিক সমজাতীয় মান ধারণ করতে সক্ষম, যেখানে টুপল বিভিন্ন ধরনের মান একসাথে ধারণ করতে সক্ষম। Haskell এ এই ডেটা স্ট্রাকচারগুলির সঠিক ব্যবহার প্রোগ্রামিংকে আরও দক্ষ এবং পরিষ্কার করে তোলে।

Content added By

Haskell এ List এবং Tuple এর মৌলিক ধারণা

Haskell এ List এবং Tuple হলো দুটি গুরুত্বপূর্ণ ডেটা স্ট্রাকচার, যা ডেটা সংরক্ষণ এবং সংগঠনের জন্য ব্যবহৃত হয়। এই দুইটি ডেটা স্ট্রাকচারের নিজস্ব বৈশিষ্ট্য এবং ব্যবহার ক্ষেত্র রয়েছে।


List

List হলো Haskell এর একটি মৌলিক ডেটা স্ট্রাকচার, যা এক ধরনের সিকোয়েন্স বা ক্রমিক ডেটা রাখে। Haskell এ List হলো একটি হোমোজেনিয়াস ডেটা স্ট্রাকচার, অর্থাৎ এর মধ্যে থাকা সব উপাদানের টাইপ একই হতে হবে।

List এর বৈশিষ্ট্য:

  • একটি List তৈরি করতে [ ] ব্যবহার করা হয়।
  • List-এর প্রতিটি উপাদান একই টাইপের হতে হবে (যেমন সব Int বা সব String)।
  • List এর উপাদানগুলো ক্রমান্বয়ে থাকে এবং এদের অ্যাক্সেস করা বা পরিবর্তন করা সহজ।
  • List একটি ইমিউটেবল ডেটা স্ট্রাকচার, অর্থাৎ একবার তৈরি হলে এর মান পরিবর্তন করা যায় না।

উদাহরণ:

myList :: [Int]
myList = [1, 2, 3, 4, 5]

এখানে myList একটি Int টাইপের List, যা [1, 2, 3, 4, 5] উপাদানগুলো ধারণ করে।

List এর অপারেশন:

  1. Head: List এর প্রথম উপাদান রিটার্ন করে।

    head [1, 2, 3] -- আউটপুট: 1
  2. Tail: প্রথম উপাদান বাদ দিয়ে বাকি List রিটার্ন করে।

    tail [1, 2, 3] -- আউটপুট: [2, 3]
  3. Length: List এর দৈর্ঘ্য প্রদান করে।

    length [1, 2, 3] -- আউটপুট: 3
  4. Concatenate: দুটি List একত্রিত করতে ++ অপারেটর ব্যবহার করা হয়।

    [1, 2] ++ [3, 4] -- আউটপুট: [1, 2, 3, 4]
  5. Element Addition: : অপারেটর ব্যবহার করে নতুন উপাদান যুক্ত করা হয়।

    0 : [1, 2, 3] -- আউটপুট: [0, 1, 2, 3]

Tuple

Tuple হলো Haskell এর আরেকটি গুরুত্বপূর্ণ ডেটা স্ট্রাকচার, যা একাধিক মান একত্রে ধরে রাখতে ব্যবহার করা হয়। Tuple এর মধ্যে থাকা উপাদানগুলির টাইপ এক হতে হবে এমন কোন বাধ্যবাধকতা নেই, অর্থাৎ একটি Tuple হেটেরোজেনিয়াস ডেটা স্ট্রাকচার।

Tuple এর বৈশিষ্ট্য:

  • Tuple তৈরি করতে ( ) ব্যবহার করা হয়।
  • Tuple এর উপাদানগুলির টাইপ ভিন্ন হতে পারে (যেমন একটি Int এবং একটি String একসাথে রাখা যাবে)।
  • Tuple একটি নির্দিষ্ট আকারের ডেটা স্ট্রাকচার এবং এটির আকার পরিবর্তন করা যায় না।
  • Tuple সাধারণত ফিক্সড আকারের ডেটা ধারণ করতে ব্যবহৃত হয়।

উদাহরণ:

myTuple :: (Int, String, Bool)
myTuple = (1, "Hello", True)

এখানে myTuple একটি Tuple, যা একটি Int, একটি String, এবং একটি Bool ধারণ করে।

Tuple এর অপারেশন:

  1. fst: দুটি উপাদান বিশিষ্ট Tuple এর প্রথম উপাদান রিটার্ন করে।

    fst (1, "Hello") -- আউটপুট: 1
  2. snd: দুটি উপাদান বিশিষ্ট Tuple এর দ্বিতীয় উপাদান রিটার্ন করে।

    snd (1, "Hello") -- আউটপুট: "Hello"
  3. Accessing Elements: বৃহত্তর Tuple এর উপাদানগুলোতে সরাসরি fst বা snd এর মাধ্যমে অ্যাক্সেস করা যায় না, এজন্য pattern matching ব্যবহার করতে হয়।

    let (x, y, z) = (1, "Hello", True)
    -- x = 1, y = "Hello", z = True

পার্থক্য: List এবং Tuple

বৈশিষ্ট্যListTuple
টাইপহোমোজেনিয়াস (একই টাইপের উপাদান)হেটেরোজেনিয়াস (বিভিন্ন টাইপের উপাদান থাকতে পারে)
আকারপরিবর্তনযোগ্য আকার (dynamic size)নির্দিষ্ট আকার (fixed size)
সিনট্যাক্স[1, 2, 3](1, "Hello", True)
মিউটেবিলিটিইমিউটেবলইমিউটেবল
অ্যাপ্লিকেশনক্রমিক ডেটা স্টোর করতেনির্দিষ্ট আকারের ডেটা স্টোর করতে

উদাহরণ: List এবং Tuple একত্রে ব্যবহার

students :: [(String, Int)]
students = [("Alice", 20), ("Bob", 22), ("Charlie", 19)]

এখানে:

  • students একটি List যেখানে প্রতিটি উপাদান একটি Tuple হিসেবে সংজ্ঞায়িত করা হয়েছে।
  • প্রতিটি Tuple এর প্রথম উপাদান String এবং দ্বিতীয় উপাদান Int

উপসংহার

List এবং Tuple Haskell এর গুরুত্বপূর্ণ ডেটা স্ট্রাকচার যা ডেটা সংরক্ষণ এবং পরিচালনায় বিভিন্ন সুবিধা প্রদান করে। যেখানে List একই ধরনের ডেটার ক্রমিক সংগ্রহ সংরক্ষণে উপযোগী, সেখানে Tuple বিভিন্ন ধরনের ডেটার নির্দিষ্ট সংগ্রহ সংরক্ষণে কার্যকরী।

Content added By

Haskell এ List Operations: Head, Tail, Map, Filter

Haskell একটি ফাংশনাল প্রোগ্রামিং ভাষা এবং এর অন্যতম শক্তিশালী বৈশিষ্ট্য হলো লিস্ট (List) ডেটা স্ট্রাকচার। লিস্ট ব্যবহারের জন্য বেশ কিছু ফাংশন এবং অপারেশন রয়েছে, যার মাধ্যমে লিস্টের উপাদানগুলি খুব সহজেই প্রসেস করা যায়। এখানে Head, Tail, Map, এবং Filter এর ব্যবহার তুলে ধরা হবে।


১. Head (হেড)

Head ফাংশনটি একটি লিস্টের প্রথম উপাদানকে রিটার্ন করে। এটি একটি সাধারণ এবং গুরুত্বপূর্ণ অপারেশন যখন আপনি লিস্টের প্রথম উপাদান বের করতে চান।

ব্যবহার:

head :: [a] -> a

head ফাংশনটি একটি লিস্ট নেয় এবং সেই লিস্টের প্রথম উপাদান প্রদান করে।

উদাহরণ:

Prelude> head [1, 2, 3, 4]
1

Prelude> head ["apple", "banana", "cherry"]
"apple"

এখানে, head ফাংশনটি প্রথম উপাদানটি রিটার্ন করেছে। প্রথমে 1 এবং পরেরটি "apple"

Note: যদি লিস্টটি খালি হয়, তাহলে head ফাংশন একটি run-time error দেবে।

Prelude> head []
*** Exception: Prelude.head: empty list

২. Tail (টেইল)

Tail ফাংশনটি একটি লিস্টের প্রথম উপাদান বাদে বাকি সমস্ত উপাদান রিটার্ন করে। এটি লিস্টের প্রথম উপাদান বাদে অবশিষ্ট অংশ প্রদান করে।

ব্যবহার:

tail :: [a] -> [a]

tail ফাংশনটি একটি লিস্ট নেয় এবং সেই লিস্টের প্রথম উপাদান বাদে বাকি লিস্ট প্রদান করে।

উদাহরণ:

Prelude> tail [1, 2, 3, 4]
[2, 3, 4]

Prelude> tail ["apple", "banana", "cherry"]
["banana", "cherry"]

এখানে, tail ফাংশনটি প্রথম উপাদান বাদে বাকি অংশকে রিটার্ন করেছে। প্রথমে [2, 3, 4] এবং পরেরটি ["banana", "cherry"]

Note: যদি লিস্টটি খালি হয়, তাহলে tail ফাংশনও একটি run-time error দেবে।

Prelude> tail []
*** Exception: Prelude.tail: empty list

৩. Map (ম্যাপ)

Map ফাংশনটি একটি ফাংশন নেয় এবং একটি লিস্টের প্রতিটি উপাদানের ওপর সেই ফাংশনটি প্রয়োগ করে একটি নতুন লিস্ট তৈরি করে। এটি একটি হাইঅর্ডার ফাংশন, যা লিস্টের প্রতিটি উপাদানের সাথে কাজ করে এবং নতুন একটি লিস্ট তৈরি করে।

ব্যবহার:

map :: (a -> b) -> [a] -> [b]

map ফাংশনটি একটি ফাংশন নেয় যা একটি উপাদানকে ইনপুট হিসেবে গ্রহণ করে এবং একটি নতুন উপাদান প্রদান করে। তারপর এটি সেই ফাংশনটি লিস্টের প্রতিটি উপাদানে প্রয়োগ করে।

উদাহরণ:

Prelude> map (*2) [1, 2, 3, 4]
[2, 4, 6, 8]

Prelude> map (++ " fruit") ["apple", "banana", "cherry"]
["apple fruit", "banana fruit", "cherry fruit"]

এখানে, প্রথমে map (*2) ফাংশনটি লিস্টের প্রতিটি উপাদানকে দুই গুণ করেছে, এবং পরবর্তীতে map (++ " fruit") ফাংশনটি প্রতিটি উপাদানের সাথে " fruit" যোগ করেছে।


৪. Filter (ফিল্টার)

Filter ফাংশনটি একটি শর্তের ভিত্তিতে একটি লিস্টের উপাদানগুলিকে ফিল্টার করে। এটি একটি ফাংশন নেয় যা একটি উপাদান এবং একটি শর্ত পরীক্ষা করে এবং সত্য হলে সেই উপাদানটি নতুন লিস্টে অন্তর্ভুক্ত করে।

ব্যবহার:

filter :: (a -> Bool) -> [a] -> [a]

filter ফাংশনটি একটি শর্ত নির্ধারণকারী ফাংশন নেয় এবং সেই শর্তে মেলে এমন উপাদানগুলি একটি নতুন লিস্টে প্রদান করে।

উদাহরণ:

Prelude> filter even [1, 2, 3, 4, 5, 6]
[2, 4, 6]

Prelude> filter (> 3) [1, 2, 3, 4, 5, 6]
[4, 5, 6]

এখানে, প্রথমে filter even ফাংশনটি শুধু ইভেন (যুগল) সংখ্যাগুলিকে রিটার্ন করেছে, এবং পরবর্তীতে filter (> 3) ফাংশনটি ৩ এর চেয়ে বড় সংখ্যাগুলিকে ফিল্টার করেছে।


List Operations এর সংক্ষিপ্ত সারাংশ

অপারেশনফাংশনব্যাখ্যা
Headheadএকটি লিস্টের প্রথম উপাদান প্রদান করে।
Tailtailএকটি লিস্টের প্রথম উপাদান বাদে বাকি উপাদানগুলি প্রদান করে।
Mapmapএকটি ফাংশনকে লিস্টের প্রতিটি উপাদানে প্রয়োগ করে নতুন লিস্ট তৈরি করে।
Filterfilterএকটি শর্ত অনুসারে লিস্টের উপাদানগুলো ফিল্টার করে।

উপসংহার

Haskell এ List Operations যেমন Head, Tail, Map, এবং Filter অত্যন্ত কার্যকরী এবং গুরুত্বপূর্ণ টুলস। এই অপারেশনগুলির মাধ্যমে আপনি লিস্টের উপাদানগুলির সাথে কার্যকরভাবে কাজ করতে পারেন এবং তাদের ওপর বিভিন্ন অপারেশন বা শর্ত প্রয়োগ করে নতুন লিস্ট তৈরি করতে পারেন। এই ফাংশনাল অপারেশনগুলির মাধ্যমে কোড আরও সংক্ষিপ্ত, পরিষ্কার, এবং কার্যকরী হয়, যা ফাংশনাল প্রোগ্রামিং এর মূল দৃষ্টিভঙ্গির সাথে সামঞ্জস্যপূর্ণ।

Content added By

Haskell এ List Comprehensions এবং তাদের ব্যবহার

List Comprehensions Haskell এর একটি শক্তিশালী বৈশিষ্ট্য যা কোডকে আরও সংক্ষিপ্ত এবং পরিষ্কার করে তোলে। এটি লিস্টের উপাদানগুলি থেকে নতুন লিস্ট তৈরি করতে ব্যবহৃত হয়, যেখানে আপনি কেবল একটি একক লাইনেই একাধিক শর্ত এবং রূপান্তর নির্ধারণ করতে পারেন।

List comprehensions Haskell এ সাধারণত do notation অথবা map/filter এর বিকল্প হিসেবে ব্যবহৃত হয়। এটি একটি শক্তিশালী টুল যখন আপনাকে একটি লিস্ট থেকে নির্দিষ্ট উপাদান বের করতে হয় বা তার ওপর কিছু অপারেশন করতে হয়।

1. List Comprehensions এর গঠন (Syntax)

List comprehension এর সাধারণ গঠন হলো:

[expression | element <- list, condition]

এখানে:

  • expression: এটি সেই কাজ বা রূপান্তর যা আপনি করতে চান (যেমন, নতুন উপাদান তৈরি করা)।
  • element <- list: এটি সেই উপাদানকে চিহ্নিত করে যা লিস্টের প্রতিটি উপাদানের সাথে তুলনা করা হবে।
  • condition: এটি একটি শর্ত, যার মাধ্যমে নির্দিষ্ট উপাদানগুলো ফিল্টার করা হবে (অথবা আপনি চাইলে এটি বাদও দিতে পারেন)।

উদাহরণ:

[ x * 2 | x <- [1, 2, 3, 4, 5] ]

এখানে, [ x * 2 | x <- [1, 2, 3, 4, 5] ] লিস্টের প্রতিটি উপাদানকে দুই গুণ করবে, যার ফলস্বরূপ:

[2, 4, 6, 8, 10]

এটি লিস্টের প্রতিটি উপাদান x নেয় এবং x * 2 রিটার্ন করে।


2. Condition সহ List Comprehension

List comprehension এর মধ্যে শর্ত (condition) ব্যবহার করে লিস্টের নির্দিষ্ট উপাদান নির্বাচন করা যেতে পারে। উদাহরণস্বরূপ:

[ x | x <- [1, 2, 3, 4, 5], x `mod` 2 == 0 ]

এখানে, x শুধুমাত্র এমন সংখ্যাগুলোর জন্য নির্বাচিত হবে যা ২ দ্বারা বিভাজ্য। অর্থাৎ, শর্ত x mod 2 == 0 এর মাধ্যমে শুধুমাত্র EVEN সংখ্যাগুলি নির্বাচিত হবে।

ফলস্বরূপ:

[2, 4]

3. Multiple Generators এবং Conditions

Haskell এ একটি list comprehension এ একাধিক generators এবং conditions থাকতে পারে। একাধিক জেনারেটর এবং শর্ত ব্যবহার করে আরও জটিল লিস্ট তৈরি করা যেতে পারে।

উদাহরণ ১: একাধিক জেনারেটর

[ (x, y) | x <- [1, 2], y <- [3, 4] ]

এখানে, লিস্টের প্রতিটি উপাদান x এবং y এর সন্নিবেশ হবে। অর্থাৎ, এটি [ (1, 3), (1, 4), (2, 3), (2, 4) ] এর সমান হবে।

ফলস্বরূপ:

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

উদাহরণ ২: একাধিক শর্ত

[ x | x <- [1..10], x `mod` 2 == 0, x > 5 ]

এখানে, শুধুমাত্র এমন সংখ্যাগুলো নির্বাচন করা হবে যেগুলি ২ দ্বারা বিভাজ্য এবং ৫ এর বেশি।

ফলস্বরূপ:

[6, 8, 10]

এখানে প্রথম শর্তে x গুলির মধ্যে এমন সংখ্যাগুলি নির্বাচন করা হয়েছে যা ২ দ্বারা বিভাজ্য, এবং পরবর্তী শর্তে ফিল্টার করা হয়েছে ৫ এর বেশি সংখ্যাগুলি।


4. List Comprehensions with Tuples

Haskell এ Tuples এর সাথে list comprehensions ব্যবহার করা যেতে পারে। এটি এমন একটি কেস যেখানে আপনি একাধিক মানের সমন্বয়ে নতুন লিস্ট তৈরি করতে পারেন।

উদাহরণ:

[ (x, y) | x <- [1, 2, 3], y <- ['a', 'b', 'c'] ]

এখানে, x এবং y এর প্রতিটি সংমিশ্রণ একটি টিউপল তৈরি করবে।

ফলস্বরূপ:

[(1,'a'),(1,'b'),(1,'c'),(2,'a'),(2,'b'),(2,'c'),(3,'a'),(3,'b'),(3,'c')]

এটি x এবং y এর সকল সংমিশ্রণ নিয়ে একটি নতুন লিস্ট তৈরি করে।


5. List Comprehension with Functions

List comprehension এর সাথে ফাংশনও ব্যবহার করা যেতে পারে। এটি খুবই কার্যকরী যখন আপনি লিস্টের উপর কিছু নির্দিষ্ট ফাংশন প্রয়োগ করতে চান।

উদাহরণ:

[ length x | x <- ["apple", "banana", "cherry"] ]

এখানে, আমরা length ফাংশনটি x এর প্রতিটি উপাদানে প্রয়োগ করেছি। ফলস্বরূপ, এটি প্রতিটি শব্দের দৈর্ঘ্য প্রদান করবে।

ফলস্বরূপ:

[5, 6, 6]

এখানে "apple", "banana", এবং "cherry" শব্দগুলির দৈর্ঘ্য দেওয়া হয়েছে।


6. Nested List Comprehensions

এটি এমন একটি কৌশল যেখানে একটি list comprehension এর ভিতরে আরেকটি list comprehension থাকে। এটি সাধারণত একাধিক লেভেল বা প্যারামিটার নিয়ে কাজ করার সময় ব্যবহৃত হয়।

উদাহরণ:

[ [x, y] | x <- [1, 2], y <- [3, 4] ]

এখানে, আমরা দুটি লিস্ট তৈরি করছি, একটি ১ এবং ২ এর জন্য, এবং অন্যটি ৩ এবং ৪ এর জন্য। প্রতিটি জেনারেটরের সাথে একটি লিস্ট তৈরি হয়।

ফলস্বরূপ:

[[1, 3], [1, 4], [2, 3], [2, 4]]

এখানে, আমাদের মূল লিস্টটি দুটি উপাদানের সাথে তৈরি হয় (যেমন, [1, 3], [1, 4], [2, 3], [2, 4])।


উপসংহার

List Comprehensions Haskell এ একটি শক্তিশালী টুল যা কোডকে সংক্ষিপ্ত, পরিষ্কার এবং কার্যকরী করতে সহায়ক। এটি আপনাকে লিস্টের উপাদানগুলির উপর কাজ করার সময় শর্ত ও রূপান্তরের মাধ্যমে নতুন লিস্ট তৈরি করতে সাহায্য করে। একাধিক generators, conditions, tuples, এবং functions ব্যবহার করে আপনি জটিল কাজ সহজে করতে পারেন। Haskell এ List Comprehension এর মাধ্যমে আপনি অনেক ধরনের ডেটা ম্যানিপুলেশন এবং রূপান্তর খুব সহজেই করতে পারবেন।

Content added By

Haskell এ Tuples এর সাথে কাজ এবং Pairing Elements

Tuples হলো Haskell-এর একটি ডেটা স্ট্রাকচার, যা একাধিক মান (values) ধারণ করতে সক্ষম, যেগুলি এক বা একাধিক টাইপের হতে পারে। এটি একটি অর্ডারড ডেটা স্ট্রাকচার, যেখানে প্রতিটি উপাদান নির্দিষ্ট অবস্থানে থাকে এবং এটি সাধারণত যুক্ত হতে পারে বিভিন্ন ডেটা টাইপের।

Pairing elements বলতে বোঝানো হয় একাধিক মানকে একসঙ্গে জোড়া (pair) আকারে সাজানো। সাধারণত, Tuple এ দুটি উপাদানকে একত্রিত করা হয়, যা Haskell-এ একটি Pair হিসেবে পরিচিত।


1. Tuples কি?

Tuples একটি কনটেইনার বা ডেটা স্ট্রাকচার যা একাধিক মান ধারণ করতে পারে। Haskell এ, একটি Tuple দুইটি, তিনটি, বা তার বেশি উপাদান ধারণ করতে পারে। Haskell এ একটি Tuple সাধারণত () (প্যারেনথিসিস) দিয়ে পরিবেষ্টিত হয় এবং এর মধ্যে উপাদানগুলো কমা দিয়ে আলাদা করা হয়।

উদাহরণ:

  • Tuple with two elements (Pair):

    pair :: (Int, String)
    pair = (5, "Hello")

    এখানে, pair একটি Tuple যেটি একটি Int এবং একটি String ধারণ করে। Tuple টি { 5, "Hello" } এর মতো হবে।

  • Tuple with three elements:

    triple :: (Int, String, Bool)
    triple = (5, "Hello", True)

    এখানে, triple একটি Tuple যেটি একটি Int, একটি String, এবং একটি Bool ধারণ করে।

  • Tuple with four or more elements:

    quadruple :: (Int, String, Bool, Double)
    quadruple = (5, "Hello", True, 3.14)

    Tuple এর মধ্যে যতগুলো উপাদান থাকতে পারে, ততগুলো টাইপ মিশ্রিত হতে পারে।


2. Pairing Elements (Pairing with Tuples)

Pairing বা pairing elements বলতে বোঝানো হয় দুটি ভিন্ন ধরনের উপাদানকে একটি Tuple আকারে একত্রিত করা। এটি সাধারণত দুইটি ভিন্ন ডেটা টাইপের মানকে একত্রিত করার জন্য ব্যবহার করা হয়। Haskell এ Pair বা দুটি উপাদানকে একটি Tuple আকারে একত্রিত করার জন্য এটি ব্যবহৃত হয়।

2.1. Creating a Pair

যদি দুটি মানকে একত্রিত করতে চান, আপনি একটি Tuple ব্যবহার করতে পারেন। নিচে একটি উদাহরণ দেওয়া হল যেখানে দুটি ভিন্ন ডেটা টাইপের মান একটি Tuple আকারে একত্রিত করা হয়েছে:

pairExample :: (Int, String)
pairExample = (1, "Hello")

এখানে, pairExample একটি pair যেটি একটি Int এবং একটি String ধারণ করে।

2.2. Accessing Elements of a Pair

একটি Tuple বা Pair এর উপাদানগুলি অ্যাক্সেস করতে, Haskell এ pattern matching ব্যবহার করা হয়।

firstElement :: (Int, String) -> Int
firstElement (x, _) = x

secondElement :: (Int, String) -> String
secondElement (_, y) = y

এখানে:

  • firstElement ফাংশনটি Tuple এর প্রথম উপাদানকে ফেরত দেয়।
  • secondElement ফাংশনটি Tuple এর দ্বিতীয় উপাদানকে ফেরত দেয়।

2.3. Swapping Elements of a Pair

এটি একটি সাধারণ প্রয়োগ যেখানে Tuple এর প্রথম এবং দ্বিতীয় উপাদান দুটি জায়গায় বদলানো হচ্ছে।

swapPair :: (a, b) -> (b, a)
swapPair (x, y) = (y, x)

এখানে swapPair ফাংশনটি একটি Pair নিয়ে এসে প্রথম এবং দ্বিতীয় উপাদানগুলিকে বদলায় এবং একটি নতুন Tuple ফিরিয়ে দেয়।

2.4. Using Pairs in Functions

Tuples (pairing elements) ফাংশনের আর্গুমেন্ট বা রিটার্ন ভ্যালু হিসেবে খুবই উপকারী। এখানে একটি উদাহরণ দেওয়া হল যেখানে একটি ফাংশন দুটি উপাদান গ্রহণ করে এবং তাদের যোগফল প্রদান করে:

addPair :: (Int, Int) -> Int
addPair (x, y) = x + y

এখানে, addPair ফাংশনটি একটি Pair গ্রহণ করে (যেটি দুটি Int টাইপের উপাদান ধারণ করে) এবং তাদের যোগফল প্রদান করে।


3. Tuples and Pairing with Lists

হ্যাসকেল এ Tuple এবং Lists একত্রে ব্যবহার করা যায়। এটি হ্যাসকেলের একটি শক্তিশালী বৈশিষ্ট্য যা একাধিক মানের সংমিশ্রণ এবং বিভিন্ন ডেটা টাইপের উপাদানকে একত্রিত করতে সাহায্য করে।

উদাহরণ:

listOfPairs :: [(Int, String)]
listOfPairs = [(1, "One"), (2, "Two"), (3, "Three")]

এখানে, listOfPairs একটি লিস্ট, যেখানে প্রতিটি উপাদান একটি Pair (Tuple) ধারণ করছে। প্রতিটি Tuple এর প্রথম উপাদান একটি Int এবং দ্বিতীয় উপাদান একটি String


4. Practical Example of Pairing Elements

ধরা যাক, আপনি একটি প্রোগ্রাম লিখছেন যা বিভিন্ন নামের পাশে তাদের বয়সের মান ধারণ করবে। আপনি Pair ব্যবহার করে নাম এবং বয়সকে একটি Tuple আকারে সংরক্ষণ করতে পারেন:

nameAgePair :: (String, Int)
nameAgePair = ("John", 25)

এখানে, "John" এবং 25 একটি Tuple আকারে একত্রিত করা হয়েছে। এটি নাম এবং বয়সের একটি Pair হিসেবে কাজ করে।


5. Conclusion

  • Tuples হল একটি ডেটা স্ট্রাকচার যা একাধিক মান ধারণ করতে সক্ষম, এবং এটি এক বা একাধিক টাইপের হতে পারে।
  • Pairing একটি সাধারণ কৌশল যেখানে দুটি উপাদানকে একত্রিত করা হয় এবং এটি একটি Tuple আকারে সংরক্ষণ করা হয়।
  • Haskell এ Pattern Matching এবং Recursion এর মাধ্যমে Tuple এর উপাদানগুলি অ্যাক্সেস করা যায়।
  • List of Pairs ব্যবহারের মাধ্যমে একাধিক Pair বা Tuple ধারণ করা সম্ভব, যা কোডের স্থিতিশীলতা এবং কার্যকারিতা বাড়ায়।

এই বৈশিষ্ট্যগুলি Haskell এ তথ্য সংগঠিত এবং প্রক্রিয়া করার একটি শক্তিশালী উপায়।

Content added By
Promotion

Are you sure to start over?

Loading...