কম্পিউটার বিজ্ঞান এ, ফ্লয়েড – ওয়ারশাল অ্যালগরিদম (ফ্লয়েডের অ্যালগরিদম, রয়-ওয়ারশাল অ্যালগরিদম, রায়-ফ্লয়েড অ্যালগরিদম বা ডাব্লুএফআইআই অ্যালগরিদম নামেও পরিচিত) হ'ল ধনাত্মক বা নেতিবাচক প্রান্তের ওজনযুক্ত গ্রাফের মধ্যে সংক্ষিপ্ততম পথগুলি খুঁজে পাওয়ার জন্য একটি অ্যালগরিদম (তবে কোনও নেতিবাচক চক্র ব্যতীত)।[১][২] অ্যালগরিদমের একক সম্পাদনা সমস্ত জোড়ের কোণের মধ্যে সংক্ষিপ্ততম পথের দৈর্ঘ্য (সংযুক্ত ওজন) পাবে। যদিও এগুলি নিজেই পথের বিশদটি ফেরত দেয় না, তবে অ্যালগরিদমের সাধারণ পরিবর্তনগুলি সহ পথগুলি পুনর্গঠন করা সম্ভব। অ্যালগরিদমের সংস্করণগুলি কোনও সম্পর্কের ট্রানজিটিভ ক্লোজার সন্ধান করতেও ব্যবহার করা যেতে পারে।
ফ্লয়েড – ওয়ারশাল অ্যালগরিদম গতিশীল প্রোগ্রামিংয়ের একটি উদাহরণ এবং এটি ১৯৬২ সালে রবার্ট ফ্লয়েড দ্বারা বর্তমানে প্রকাশিত হয়েছিল।[৩] এটি মূলত ১৯৫৯ সালে বার্নার্ড রায়[৪] এবং ১৯৬২ সালে স্টিফেন ওয়ারশালের[৫] দ্বারা প্রকাশিত অ্যালগরিদমের মতোই। এটি ক্লিনির অ্যালগরিদম (১৯৫৬ সালে প্রকাশিত)[৬] সাথে একটি নিয়মিত অভিব্যক্তিতে সীমাবদ্ধ অটোমেটনকে নিয়মিত অভিব্যক্তিতে রূপান্তরিত করার জন্যও ব্যবহার করা হয়। তিন নেস্টেড লুপ হিসাবে আলগোরিদিম আধুনিক সূচনাটি প্রথম প্রকাশিত হয়েছিল পিটার ইনগারম্যান, ১৯৬২ সালে।[৭]
অ্যালগরিদমের মূল ধারণাটি হ'ল যে কোনও দুটি শীর্ষবিন্দু মধ্যে বেশ কয়েকটি সংখ্যক ইনক্রিমেন্টাল পর্যায়ে সবচেয়ে সংক্ষিপ্ত পথ সন্ধানের প্রক্রিয়াটিকে বিভাজন করা। ধরে নাও একটি পুনর্নির্দেশিত ওজনযুক্ত গ্রাফ G, যার মধ্যে n খানা শীর্ষবিন্দু রয়েছে। এই গ্রাফ G এর জন্য একটি অপেক্ষক d[i][j] ধরে নেয়া হলো যার মধ্যে যে কোনো দুই শীর্ষবিন্দু i ও j এর সংক্ষিপ্ততম পথগুলি সংরক্ষণ করা হবে।
প্রাথমিকভাবে, আমরা d[i][j] = দিয়ে ম্যাট্রিক্স পূরণ করতে পারি যদি i এবং j শীর্ষবিন্দুর মধ্যে ওজনের একটি প্রান্ত থাকে। তবে যদি i ও j এর মধ্যে কোনো প্রান্ত না থাকে তবে d[i][j] = ∞ ধরা হবে। যদিও কার্যকরীভাবে কিছু উচ্চ মান ধরা হয। এবার আমরা প্রত্যেক k-তম ধাপে আমরা (i, j) শীর্ষকোণগুলির দূরত্বগুলো গণনা করে ম্যাট্রিক্স d[i][j] তে সংরক্ষণ করবো। এই গণনা করার জন্যে দুটি মৌলিকভাবে পৃথক কেস রয়েছে:
এই দুটি কেসের সংমিশ্রণে আমরা দেখতে পেলাম যে আমরা সমস্ত শীর্ষবিন্দু জোড়া (i ,j) এর দৈর্ঘ্য গণনা করার k-তম ধাপে নিম্নলিখিত ভাবে করতে পারি :
dk[i][j] = dk-1[i][j], dk-1[i][k] + dk-1[k][j] )
ফ্লয়েড ওয়ারশ্যালের অ্যালগরিদমের C++ কোড নিম্নরূপ:
vector<vector<int>> floydWarshall (vector<vector<int>> &graph)
{
/* vector<vector<int>> graph হলো অন্তিক ম্যাট্রিক্স।
এই অন্তিক ম্যাট্রিক্স এ প্রত্যেক শীর্ষবিন্দু জোড়ার ওজন
সংরক্ষণ করা আছে। ্রিক্স */
int i, j, k;
int n=graph.size();//শীর্ষবিন্দুর সংখ্যা
/* vector<vector<int>> dist এই ম্যাট্রিক্স এ
অবশেষে প্রতিটি শীর্ষবিন্দু জোড়ার
সংক্ষিপ্ততম পথটির দূরত্ব সংরক্ষণ
করা থাকবে।*/
vector<vector<int>> dist(n,vector<int> (n,INT_MAX));
/*প্রাথমিকভাবে সমস্ত প্রান্তের মানগুলি
dist ম্যাট্রিক্সে সংরক্ষণ ক রা হচ্ছে
*/
for (i = 0; i < n; i++)
for (j = 0; j < n; j++)
dist[i][j] = graph[i][j];
/* ফ্লয়েড-ওয়ারশল অ্যালগোরিদম */
for (k = 0; k < n; k++)
{
for (i = 0; i < n; i++)
{
for (j = 0; j < n; j++)
{
if (dist[i][k] + dist[k][j] < dist[i][j])
dist[i][j] = dist[i][k] + dist[k][j];
}
}
}
return dist;
}
উপরের অ্যালগরিদমটি নিচের ছবিতে ব্যবহার করা হয়েছে :
K এর প্রতিটি পুনরাবৃত্তির দূরত্বের ম্যাট্রিক্সটি হবে:
k = 0 | j | ||||
1 | 2 | 3 | 4 | ||
---|---|---|---|---|---|
i | 1 | 0 | ∞ | −2 | ∞ |
2 | 4 | 0 | 3 | ∞ | |
3 | ∞ | ∞ | 0 | 2 | |
4 | ∞ | −1 | ∞ | 0 |
k = 1 | j | ||||
1 | 2 | 3 | 4 | ||
---|---|---|---|---|---|
i | 1 | 0 | ∞ | −2 | ∞ |
2 | 4 | 0 | 2 | ∞ | |
3 | ∞ | ∞ | 0 | 2 | |
4 | ∞ | −1 | ∞ | 0 |
k = 2 | j | ||||
1 | 2 | 3 | 4 | ||
---|---|---|---|---|---|
i | 1 | 0 | ∞ | −2 | ∞ |
2 | 4 | 0 | 2 | ∞ | |
3 | ∞ | ∞ | 0 | 2 | |
4 | 3 | −1 | 1 | 0 |
k = 3 | j | ||||
1 | 2 | 3 | 4 | ||
---|---|---|---|---|---|
i | 1 | 0 | ∞ | −2 | 0 |
2 | 4 | 0 | 2 | 4 | |
3 | ∞ | ∞ | 0 | 2 | |
4 | 3 | −1 | 1 | 0 |
k = 4 | j | ||||
1 | 2 | 3 | 4 | ||
---|---|---|---|---|---|
i | 1 | 0 | −1 | −2 | 0 |
2 | 4 | 0 | 2 | 4 | |
3 | 5 | 1 | 0 | 2 | |
4 | 3 | −1 | 1 | 0 |
এই অ্যালগরিদমের জন্য:
গড় সময়ের জটিলতা =
এবং,
খারাপ স্থান জটিলতা =