Loading AI tools
خوارزمية لإيجاد أقصر مسار من عقدة محددة نحو كل عقد بيان من ويكيبيديا، الموسوعة الحرة
خوارزمية بلمان - فورد (بالإنجليزية: Bellman–Ford algorithm) تقوم بحساب الطريق الأقصر والأسرع في مخطط موجه من خلال مصدر القمة، على عكس خوارزمية دجكسترا فانها تقوم بحساب الحواف الموجهة السالبة (إضافة إلى الموجبة)، و تمت تسميتها نسبة للعالمين ريتشارد بلمان وفورد لستر.[3] تسمح هذه الخوارزمية بوجود عدة أقواس أو دوائر ذات اتجاه سالب كما تسمح بالكشف عن وجود دوائر ماصة أي دوائر ذات وزن إجمالي سالب (اتجاه سالب)، قابلة للحصول من مصدر القمة.
الصنف | |
---|---|
بنية البيانات | |
مشتق من | |
المكتشف | |
سمي نسبة لـ |
أسوء حالة | |
---|---|
الحالة المُثلى | |
أسوأ حالة تعقيد مكاني |
تعتمد هذه الخوارزمية على مقاربة البرمجة الديناميكية، تشبه في هيكلها الأساسي لخوارزمية دجكسترا ولكنها عوضاً عن اختيار العقدة الأقل وزناً والتي لم يتم تمديدها، فإنها تقوم بتمديد جميع الحواف وتقوم بذلك |ق-1| مرة، حيث |ق| هو عدد القمم في المخطط، التكرار يسمح بالحصول على أصغر مسافة ممكنة على طول المخطط، في حالة عدم وجود دوائر سالبة فإن الطريق الأقصر يمر على كل عقدة مرة واحدة على الأكثر.
إجراءات بلمان - فورد(قائمة الحواف، قائمة القمم، مصدر القمة): // هذا التطبيق يأخذ في الرسم البياني، كما هو ممثل قوائم القمم والحواف، ويملى مسافة صفين. // الخطوة 1: بداية البيان: لكل قمة ق: إذا القمة هي المصدر فإن المسافة(ق) = 0 وإلا فالمسافة(ق) = مالانهاية مع السلف = معدوم // الخطوة 2: تمديد الحواف مراراً لكل ر من 1 إلى حجم (القمم - 1): لكل حافة (ق، ع) مع الوزن (و) في الحواف : إذا المسافة[ع] + و <المسافة[ق]: المسافة [ق] = المسافة [ع] + و // الخطوة 3: التحقق من وجود دورات سلبية: لكل حافة (ق، ع) مع حواف ث الوزن في: إذا المسافة[ع] + و <المسافة[ق]: خطأ "الرسم البياني يحتوي على دورات سلبية"
يمكن إظهار صحة الخوارزمية بواسطة الاستقراء الرياضي: مبرهنة: بعد تكرار للدورات:
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.