উদাহরণ: Randomized Quick Sort, Monte Carlo Algorithm

র‌্যান্ডমাইজড অ্যালগরিদম (Randomized Algorithms) - ডিজাইন এন্ড এনালাইসিস অব অ্যালগরিদম (Design and Analysis of Algorithms) - Computer Science

254

নিচে Randomized Quick Sort এবং Monte Carlo Algorithm এর উদাহরণ এবং আলোচনা করা হলো।

১. Randomized Quick Sort

Randomized Quick Sort হলো একটি দ্রুত সাজানোর অ্যালগরিদম যা সাধারণ Quick Sort এর একটি সংশোধিত সংস্করণ। এতে একটি এলোমেলোভাবে নির্বাচিত পিভট উপাদান ব্যবহার করা হয়, যা কার্যকারিতা বাড়ায় এবং worst-case সময় জটিলতা কমাতে সহায়ক।

অ্যালগরিদমের ধাপ:

  1. একটি এলোমেলো পিভট নির্বাচন করুন।
  2. সজ্জিত উপাদানগুলোকে পিভটের তুলনায় কম এবং বড় অংশে ভাগ করুন।
  3. পুনরাবৃত্তি করুন বাম এবং ডান অংশের জন্য।

উদাহরণ (Python Implementation):

import random

def randomized_partition(arr, low, high):
    pivot_index = random.randint(low, high)
    arr[pivot_index], arr[high] = arr[high], arr[pivot_index]  # Swap pivot with last element
    pivot = arr[high]
    i = low - 1

    for j in range(low, high):
        if arr[j] < pivot:
            i += 1
            arr[i], arr[j] = arr[j], arr[i]  # Swap elements
    arr[i + 1], arr[high] = arr[high], arr[i + 1]  # Move pivot to correct position
    return i + 1

def randomized_quick_sort(arr, low, high):
    if low < high:
        pivot_index = randomized_partition(arr, low, high)
        randomized_quick_sort(arr, low, pivot_index - 1)
        randomized_quick_sort(arr, pivot_index + 1, high)

# উদাহরণ ব্যবহার
arr = [10, 7, 8, 9, 1, 5]
randomized_quick_sort(arr, 0, len(arr) - 1)
print("Sorted Array:", arr)  # আউটপুট হবে [1, 5, 7, 8, 9, 10]

২. Monte Carlo Algorithm

Monte Carlo Algorithm একটি প্রোবাবিলিস্টিক অ্যালগরিদম যা এলোমেলো নমুনা ব্যবহার করে সমস্যার সমাধান করে। এটি সাধারণত জটিল সমস্যাগুলি সমাধানে ব্যবহৃত হয় যেখানে সঠিক সমাধান পাওয়া কঠিন।

উদাহরণ: π (পাই) এর মান নির্ধারণ

Monte Carlo পদ্ধতি ব্যবহার করে π এর মান অনুমান করা যায়। পদ্ধতিটি একটি 2D বর্গ এবং তার ভিতরে একটি বৃত্ত তৈরি করে। এলোমেলোভাবে একটি পয়েন্ট নির্বাচন করে, যদি পয়েন্টটি বৃত্তের ভিতরে পড়ে, তবে এটি গণনা করা হয়।

অ্যালগরিদমের ধাপ:

  1. একটি ইউনিট বর্গের ভিতরে এলোমেলোভাবে পয়েন্ট তৈরি করুন।
  2. কতগুলি পয়েন্ট বৃত্তের ভিতরে পড়ছে তা গণনা করুন।
  3. π এর মান অনুমান করুন: π≈4×inside pointstotal pointsπ≈4×total pointsinside points​

উদাহরণ (Python Implementation):

import random

def monte_carlo_pi(num_samples):
    inside_circle = 0

    for _ in range(num_samples):
        x = random.uniform(-1, 1)
        y = random.uniform(-1, 1)
        if x**2 + y**2 <= 1:
            inside_circle += 1

    return 4 * inside_circle / num_samples

# উদাহরণ ব্যবহার
num_samples = 1000000
pi_estimate = monte_carlo_pi(num_samples)
print(f"Estimated value of π using {num_samples} samples: {pi_estimate}")

সারসংক্ষেপ

Randomized Quick Sort: এলোমেলোভাবে পিভট নির্বাচন করে দ্রুত সাজানোর একটি অ্যালগরিদম, যা সাধারাণত O(n log n) সময়ে কাজ করে।

Monte Carlo Algorithm: এলোমেলো নমুনা ব্যবহার করে সমস্যা সমাধানের একটি পদ্ধতি, যা জটিল সমস্যাগুলির জন্য কার্যকর হতে পারে।

উপরের উদাহরণগুলি Python এ প্রয়োগ করা হয়েছে। আপনি যদি এই সমস্যা বা অ্যালগরিদম সম্পর্কে আরও বিস্তারিত আলোচনা করতে চান বা অন্য কিছু জানতে চান, তাহলে জানাতে পারেন!

Promotion

Are you sure to start over?

Loading...