ترتيب المشطترتيب المشط خوارزمية ترتيب بسيطةً نسبياً، صممها في البداية Włodzimierz Dobosiewicz في عام 1980.[2] ثم أعاد اكتشافها Stephen Lacey و Richard Box في عام 1991.[3] وتعد تحسيناً لخوارزمية ترتيب الفقاعات. الخوارزميةالفكرة الأساسية هي إزالة السلاحف, أو القيم الصغيرة الفريبة من نهاية القائمة، فهي سبب رئيسي في تبطيء خوارزمية ترتيب الفقاعات، في حين لا تسبب الأرانب, القيم الكبيرة في بداية القائمة، أي مشكلة في ترتيب الفقاعات. عند مقارنة أي عنصرين في ترتيب الفقاعات يكون بينهما فجوة (مسافة بين العنصرين) قيمتها 1. الفكرة الأساسية في ترتيب المشط هي إمكانية جعل هذه الفجوة أكبر من 1(ترتيب شل يعتمد هو أيضاً على هذه الخوارزمية، ولكنه يعتبر تعديلاً على الترتيب بالإدراج أكثر من كونه تعديلاً على ترتيب الفقاعات). بكلام أكثر تخصصاً، تم تعديل الحلقة الداخلية في ترتيب الفقاعات، حيث تتم عملية الـتبديل الفعلية، بحيث تتناقص قيمة الفجوة بين العناصر التي تتم مقارنتها (خلال كل دورة للحقة الخارجية) بخطوات يحددها عامل الانكماش. يتم ذلك كما يلي. [ حجم الدخل\عامل الانكماش، حجم الدخل\عامل الانكماش^2, حجم الدخل\عامل الانكماش^3, ...., 1 ]. وذلك على عكس ترتيب الفقاعات، حيث تكون قيمة الفجوة ثابتة أي 1. تبدأ قيمة الفجوة من حجم القائمة التي يتم ترتيبها مقسوماً على عامل الانكماش (عادةً 1.3; انظر أدناه), ويتم ترتيب القائمة بهذه القيمة للفجوة (بعد تقريبها لأقرب عدد صحيح أصغر منها إن لزم الأمر). ثم يتم تقسيم قيمة الفجوة على عامل الانكماش مرة أخرى، ثم إعادة ترتيب المقائمة بقيمة الفجوة الجديدة، وهكذا يتم تكرار العملية حتى وصول قيمة الفجوة إلى 1. عند هذه المرحلة، تتابع خوارزمية ترتيب المشط بقيمة الفجوة 1 حتى إتمام عملية الترتيب كلّيّاً. بالتالي فهي مكافئة لترتيب الفقاعات خلال هذه المرحلة، ولكن معظم السلاحف الموجودة يكون قد تم التعامل معها، ولذلك سيكون ترتيب الفقاعات فعالاً خلال هذه المرحلة. يؤثّر معامل الانكماش بشكل كبير على ترتيب المشط. وقد اقترح المؤلف في مقاله الأصلي عن الخوارزمية قيمة 1.3 للهذا العامل.فالقيمة الصغيرة للمعامل تسبب بطء الخوارزمية لاحتياجها للمزيد من المقارنات، بينما تسبب القيمة الكبيرة للمعامل عدم حدوث أي مقارنة.وقد وجد Lacey و Box بالتجربة (عبر اختبار ترتيب المشط على أكثر من 200,000 قائمة عشوائية)أن القيمة 1.3 هي الأفضل لعامل الانكماش. شبه الكودتابع ترتيب_المشط (مصفوفة الدخل)
كرر حتى تصبح الفجوة = 1 و المبادَل = غيرصحيح س:= 0 \\«مشطٌ» واحد على قائمة الدخل نهاية حلقة التكرار انظر أيضاً
المراجع
|