Minimum Spanning Tree(MST) বের করার দুইটা অ্যালগরিদম আছে, ক্রুসকাল এবং প্রিমস অ্যালগরিদম।এখানে আমরা দেখব ক্রুসকাল অ্যালগরিদম দিয়ে কিভাবে Minimum Spanning Tree(MST) বের করা যায়। এ সম্পর্কে বিশদভাবে জানার জন্য শাফায়েত ভাইয়ের ব্লগের বিকল্প নাই।
Kruskal Algorithm(Minimum Spanning Tree):
প্রথমে সবগুলো এজ কে তাদের কস্ট/ওয়েট অনুযায়ী Non-decreasing অর্ডারে সর্ট করে ফেলতে হবে।তারপর সবচেয়ে কম কস্ট/ওয়েটের এজগুলো নেয়ে শুরু করতে হবে তবে কোন এজ নেয়ার সময় অবশ্যই চেক করতে হবে সংশ্লিষ্ট নোড দুটির মধ্যে আগে থেকেই কোন পথ/এজ আছে কি না। আগে থেকেই এজ থাকলে সেটি আর নেয়া যাবে না ,কারণ নিলেই সাইকেল ক্রিয়েট হয়ে যাবে।কোন দুটি নোডের মধ্যে আগে থেকেই এজ/পথ আছে কি না সেটা ডিসজয়েন্ট সেট এর কনসেপ্ট দিয়ে চেক করা যেতে পারে। এভাবে এজ নিতে নিতে n-1 সংখ্যক এজ নেয়া হলেই হলেই প্রোগ্রাম টারমিনেট করে দিতে হবে।
Sample Code:
Maximum Spanning Tree:
এক্ষেত্রে এজ গুলোকে শুধু Non-increasing অর্ডারে সর্ট করতে হবে।বাকি সবকিছুই Minimum Spanning Tree এর মতই।
Partial 'Minimum' Spanning Tree:
এক্ষেত্রে কিছু ফিক্সড এজ দেয়া থাকে যেগুলো নিতেই হবে।তাই এটা আসলে MST থাকে না।সেই জন্যই ক্যাপশনে Minimum কে quotes এর মধ্যে রাখা হয়েছে😏। এর সল্যুশন অ্যাপ্রোচটা খুবই সিম্পল।প্রথমে ফিক্সড এজ গুলো নিয়ে নিতে হবে।তারপর বাকি গুলোর উপর MST রান করলেই হয়ে যাবে😝।ধরি N হল গ্রাফে নোড সংখ্যা,এবং F সংখ্যক ফিক্সড এজ দেয়া আছে। তাহলে Partial 'Minimum' Spanning Tree পেতে হলে প্রথমে ফিক্সড এজ গুলো কে নেয়ার পর বাকি গুলোর উপর MST রান করে (N-1)-F সংখ্যক এজ পেলেই প্রোগ্রাম টারমিনেট করে দিতে হবে।
Sample code:
Second Best Spanning Tree:
এক্ষেত্রে রান MST করে MST এর সবগুলো এজ সেভ করে রাখতে হবে। তারপর MST এর প্রতিটা এজ একবার করে বাদ দিয়ে নতুন করে MST রান করতে হবে।এভাবে মূল MST এর প্রতিটা এজ একবার করে বাদ দিয়ে নতুন করে MST রান করে যে MST এর ভাল্যু সবচেয়ে কম হবে সেটাই হল Second Best Spanning Tree। কোন একটি এজকে বাদ দেয়ার জন্য ঐ এজকে একটা Infinite ভ্যাল্যু অ্যাসাইন করে দিলেই হবে।
Sample Code:
Sample Code:
Minimum Spanning Forest:
এক্ষেত্রে সব গুলো নোড কিছু সংখ্যক এজ দিয়ে ভিজিটেড হয়ে গেলেই প্রোগ্রাম টারমিনেট করে দিব,যদি Spanning Tree ফর্ম না হয় তবুও।Spanning Tree ফর্ম না করেই কিছু সংখ্যক এজ দিয়েই সব গুলো নোড ভিজিট করা পসিবল হবে যদি গ্রাফে একটা Spanning 'Forest' থাকে।সাধারণত কত সংখ্যক এজ(Number of Components) দিয়ে সব গুলো নোড ভিজিট করতে হবে তা বলে দেয়া থাকে,তাই তত সংখ্যক এজ নেয়া হয়ে গেলেই প্রোগ্রাম টারমিনেট করে দিতে হবে।
Sample Code:
References:
→Competitive Programming By Steven & Felix Halim
→Competitive Programmer's Handbook By Antti Laaksonen
No comments:
Post a Comment