
عدد أنواع مختلفة أكثر أو أقل من بعضها البعض مضمونة لتكون أكثر من مائة. من بينها ، هناك مجموعات فرعية من الخوارزميات تختلف اختلافًا بسيطًا عن بعضها البعض ، وتتزامن مع بعض الأفكار الرئيسية العامة. في الواقع ، في سنوات مختلفة ، يأتي أشخاص مختلفون بنفس الفرز من جديد ، ويختلفون في التفاصيل غير الأساسية.
تم العثور على مثل هذه الفكرة الحسابية في كثير من الأحيان أكثر من غيرها.
يتم إدخال كل عنصر
تقريبًا في هذا المكان للصفيف حيث يجب تحديد موقعه. اتضح مجموعة
أمر تقريبا . إلى أي نوع يتم تطبيق الفرز بواسطة إدراجات (يكون أكثر فاعلية لمعالجة المصفوفات التي يتم طلبها تقريبًا) أو تتم معالجة المناطق غير المرتبة المحلية بشكل متكرر باستخدام نفس الخوارزمية.

كُتِب هذا المقال بدعم من EDISON ، الذي يطور مجموعة واسعة من الحلول لمجموعة متنوعة من المهام: من البرامج للمحاولة عبر الإنترنت على ملابس المتاجر متعددة العلامات التجارية إلى نظام نقل LED بين السفن النهرية والبحرية .
نحن نحب نظرية الخوارزميات! ؛-)
لتقييم المكان الذي تريد وضع العنصر فيه تقريبًا ، تحتاج إلى معرفة مقدار اختلافه عن العنصر المتوسط للصفيف. للقيام بذلك ، تحتاج إلى معرفة قيم الحد الأدنى والحد الأقصى للعناصر ، وكذلك ، وحجم الصفيف.
من المفترض أن تحتوي المجموعة المصنفة على بيانات عشوائية حقًا. جميع المخترعين من هذه الطريقة يأتون إلى نفس الصيغة:
k هو المكان التقريبي في الصفيف حيث يجب أن يكون العنصر
A (
i )
min ،
max - قيم الحد الأدنى والحد الأقصى للعناصر في الصفيف
Aالحجم - عدد العناصر في الصفيف
أهذه هي الفكرة العامة. دعونا نرى في الاختلافات التي ولدت هذه الخوارزمية مرارا وتكرارا.
فرز الملك سليمان :: سليمان الفرز
تم
اقتراح هذه الطريقة (واسمها الجميل) من
قبل مستخدم
V2008n منذ حوالي 5 سنوات. كل شيء له وقته ، "وقت نثر الحجارة ووقت جمع الحجارة" (كلمات الملك سليمان من كتاب سفر الجامعة) - وفي الخوارزمية ، هذا هو بالضبط ما يحدث. أولاً ، بمساعدة الصيغة ، ننتشر العناصر في الأماكن المطلوبة في المصفوفة. نظرًا لأن الصيغة لا تعطي مكانًا دقيقًا ، ولكن تقريبيًا ، فإن العديد من العناصر القريبة من بعضها البعض تدعي قيمة بعض المراكز في وقت واحد. يتم فرز مجموعات العناصر المحلية هذه بواسطة إدراج ثم يتم تجميعها بالترتيب النهائي.
نوع الاستيفاء
"لا يوجد شيء جديد تحت الشمس" ، على حد تعبير المؤلف نفسه. تصف ويكيبيديا الفرز حسب الاستيفاء ، وتذكر بشكل مثير للريبة الفرز سليمان. كل "كومة من الأحجار" عبارة عن مجموعة ديناميكية صغيرة إضافية ، حيث توجد عناصر ذات أهمية مماثلة. الفرق الرئيسي هو أنه بعد "تشتت الحجارة" ، يتم فرز هذه المجموعات المحلية غير المصنفة من العناصر ليس عن طريق إدراج ، ولكن عن طريق فرز أنفسهم عن طريق الاستيفاء (بشكل متكرر أو في حلقة).
الصفيف المرتب هو مجموعة بيانات منفصلة يمكن اعتبارها مجموعة محدودة من القيم المعروفة لوظيفة معينة غير معروفة. في الواقع ، توزيع تقريبي من وجهة نظر الرياضيات الحسابية - وهذا هو الاستيفاء.
جافا سكريبت نوع الاستيفاء - الاسترجاعArray.prototype.interpolationSort = function() { var divideSize = new Array(); var end = this.length; divideSize[0] = end; while(divideSize.length > 0) {divide(this);} function divide(A) { var size = divideSize.pop(); var start = end - size; var min = A[start]; var max = A[start]; var temp = 0; for(var i = start + 1; i < end; i++) { if(A[i] < min) { min = A[i]; } else { if(A[i] > max) {max = A[i];} } } if(min == max) { end = end - size; } else { var p = 0; var bucket = new Array(size); for(var i = 0; i < size; i++) {bucket[i] = new Array();} for(var i = start; i < end; i++) { p = Math.floor(((A[i] - min) / (max - min)) * (size - 1)); bucket[p].push(A[i]); } for(var i = 0; i < size; i++) { if(bucket[i].length > 0) { for(var j = 0; j < bucket[i].length; j++) {A[start++] = bucket[i][j];} divideSize.push(bucket[i].length); } } } } };
جافا سكريبت نوع الاستيفاء - نسخة العودية Array.prototype.bucketSort = function() { var start = 0; var size = this.length; var min = this[0]; var max = this[0]; for(var i = 1; i < size; i++) { if (this[i] < min) { min = this[i]; } else { if(this[i] > max) {max = this[i];} } } if(min != max) { var bucket = new Array(size); for(var i = 0; i < size; i++) {bucket[i] = new Array();} var interpolation = 0; for(var i = 0; i < size; i++){ interpolation = Math.floor(((this[i] - min) / (max - min)) * (size - 1)); bucket[interpolation].push(this[i]); } for(var i = 0; i < size; i++) { if(bucket[i].length > 1) {bucket[i].bucketSort();}
الرسم البياني الفرز :: فرز الرسم البياني
هذا هو الأمثل للفرز عن طريق الاستيفاء ، والذي يحسب عدد العناصر التي تنتمي إلى مجموعات غير مفرزة المحلية. يتيح لك هذا العدد إدراج عناصر غير مفرزة مباشرة في الصفيف الناتج (بدلاً من تجميعها في صفيفات صغيرة منفصلة).
شريط جافا سكريبت فرز Array.prototype.histogramSort = function() { var end = this.length; var sortedArray = new Array(end); var interpolation = new Array(end); var hitCount = new Array(end); var divideSize = new Array(); divideSize[0] = end; while(divideSize.length > 0) {distribute(this);} function distribute(A) { var size = divideSize.pop(); var start = end - size; var min = A[start]; var max = A[start]; for(var i = start + 1; i < end; i++) { if (A[i] < min) { min = A[i]; } else { if (A[i] > max) {max = A[i];} } } if (min == max) { end = end - size; } else { for(var i = start; i < end; i++){hitCount[i] = 0;} for(var i = start; i < end; i++) { interpolation[i] = start + Math.floor(((A[i] - min) / (max - min)) * (size - 1)); hitCount[interpolation[i]]++; } for(var i = start; i < end; i++) { if(hitCount[i] > 0){divideSize.push(hitCount[i]);} } hitCount[end - 1] = end - hitCount[end - 1]; for(var i = end - 1; i > start; i--) { hitCount[i - 1] = hitCount[i] - hitCount[i - 1]; } for(var i = start; i < end; i++) { sortedArray[hitCount[interpolation[i]]] = A[i]; hitCount[interpolation[i]]++; } for(var i = start; i < end; i++) {A[i] = sortedArray[i];} } } };
نوع الاستيفاء
من أجل زيادة تحسين الحمل ، يُقترح هنا ألا نتذكر عدد العناصر ذات الأهمية المتشابهة في المجموعات التي لم يتم فرزها ، ولكن ضع علامة على بداية هذه المجموعات باستخدام علامات True / False. يعني True أن المجموعة الفرعية مصنفة بالفعل ، ويعني False أنه لم يتم فرزها بعد.
جافا سكريبت الموسومة نوع الاستيفاء Array.prototype.InterpolaionTagSort = function() { var end = this.length; if(end > 1) { var start = 0 ; var Tag = new Array(end);
فرز علامة الاستيفاء (في الموضع)
إذا لم يتم تكرار قيم العناصر في المصفوفة وتوزيعها بشكل متساوٍ (بمعنى تقريبًا - إذا كانت البيانات في شكل مفروزة تشبه تقدمًا حسابيًا) ، فيمكنك الفرز في مسار واحد ، والفرز في المكان الصحيح ، دون نقل العناصر إلى المصفوفات الوسيطة.
الترتيب حسب الاستيفاء مع التسميات (في المكان) في جافا سكريبت Array.prototype.InPlaceTagSort = function() { var n = this.length; var Tag = new Array(n); for(i = 0; i < n; i++) {Tag[i] = false;} var min = this[0]; var max = this[0]; for(i = 1; i < n; i++) { if(this[i] < min) { min = this[i]; } else { if(this[i] > max) {max = this[i];} } } var p = 0; var temp = 0; for(i = 0; i < n; i++) { while(Tag[i] == false) { p = Math.floor(((this[i] - min) / (max - min)) * (n - 1)); temp = this[i]; this[i] = this[p]; this[p] = temp; Tag[p] = true; } } };
ترتيب الفلاش :: Flashsort
ذات مرة ،
كتبت عن الفرز الذي اخترعه أستاذ الفيزياء الحيوية نيوبرت في عام 1998.
اقترح الأستاذ توزيع العناصر في عدة فصول منفصلة (يتم تحديد عضوية الفصل حسب حجم العنصر). مع وضع ذلك في الاعتبار ، تبدو الصيغة كما يلي:
بدلاً من الحجم (حجم الصفيف) ، تشير الصيغة إلى
m - عدد الفئات التي نوزع بها عناصر المصفوفة. لا تحسب الصيغة المفتاح في الصفيف حيث يجب إلقاء العنصر ، ولكن رقم الفئة الذي ينتمي إليه العنصر.
هذا التصنيف ليس سيئًا لأنه أكثر اقتصادا في الذاكرة الإضافية. إعادة توزيع العناصر يحدث في المكان. يتم تخزين تعريب الفئات فقط بشكل منفصل (حسنًا ، إذا نظرت من زاوية مختلفة ، فسيتم تخزين عدد العناصر التي تنتمي إلى فئة معينة بشكل منفصل).
حسنا ، الباقي هو نفس الأغنية.
ترتيب فلاش في جافا class FlashSort { static int n; static int m; static int[] a; static int[] l; public static void flashSort(int size) { n = size; generateRandomArray(); long start = System.currentTimeMillis(); partialFlashSort(); long mid = System.currentTimeMillis(); insertionSort(); long end = System.currentTimeMillis();
فرز تقريبي :: فرز Proxmap
هذا الفرز هو الأقدم من تلك المذكورة هنا ؛ وقد قدمه في عام 1980 البروفيسور توماس ستانديش من جامعة كاليفورنيا. في المظهر ، يبدو الأمر مختلفًا تمامًا ، ولكن إذا نظرت عن كثب ، فكل شيء على ما هو عليه.
تعمل الخوارزمية بمفهوم مثل
الضرب - وهو رقم معين قريب من بعض عناصر المصفوفة.
لتحديد ما إذا كان عنصر الصفيف عبارة عن ضربة ، يتم تطبيق
دالة تقريبية على العنصر.
البروفيسور ستانديش رتبت صفائف من الأرقام الحقيقية. كانت الدالة التقريبية تقريب الأرقام الحقيقية لأسفل إلى عدد صحيح.
هذا ، على سبيل المثال ، إذا كان الصفيف يحتوي على عناصر 2.8 ، 2 ، 2.1 ، 2.6 ، إلخ. ثم ضرب لهذه الأرقام سيكون شيطان.
الإجراء العام:
- نحن نطبق دالة تقريبية على كل عنصر ، وتحديد أي ضرب يتوافق مع العنصر التالي.
- وبالتالي ، لكل ضربة ، يمكننا حساب عدد العناصر المطابقة لهذه الضربة.
- مع العلم بعدد العناصر لجميع الزيارات ، نحدد توطين الزيارات (الحدود على اليسار) في الصفيف.
- معرفة توطين الزيارات ، نحدد توطين كل عنصر.
- بعد تحديد توطين العنصر ، نحاول إدخاله في مكانه في المصفوفة. إذا كان المكان مأخوذ بالفعل ، فنحن ننقل الجيران إلى اليمين (إذا كان العنصر أصغر منهم) لإفساح المجال للعنصر. أو إلى اليمين ، نقوم بإدراج العنصر نفسه (إذا كان أكثر من جيران).
كدالة تقريبية ، يمكنك تعيين أي واحدة بناءً على الطبيعة العامة للبيانات في الصفيف. في التطبيقات الحديثة لهذا التصنيف ، عادة ما يتم تحديد عدد مرات الدخول ليس عن طريق قذف الجزء الكسري ، ولكن باستخدام الصيغة المفضلة لدينا.
جافا سكريبت تقريب فرز Array.prototype.ProxmapSort = function() { var start = 0; var end = this.length; var A2 = new Array(end); var MapKey = new Array(end); var hitCount = new Array(end); for(var i = start; i < end; i++) {hitCount[i] = 0;} var min = this[start]; var max = this[start]; for (var i = start+1; i < end; i++){ if (this[i] < min) { min = this[i]; } else { if(this[i] > max) {max = this[i];} } }
تجزئة الفرز الإدراج الفرز :: فرز التجزئة
حسنًا ، سننتهي من مراجعة الخوارزمية
التي اقترحها
haraiser bobbyKdas منذ 6 سنوات. هذه خوارزمية هجينة تُضاف فيها الدمج ، بالإضافة إلى التوزيع والإدراج.
- يتم تقسيم الصفيف بشكل متكرر إلى نصفين ، حتى تصل في بعض الخطوات أحجام المصفوفات الفرعية إلى الحد الأدنى للحجم (المؤلف ليس له أكثر من 500 عنصر).
- عند أدنى مستوى من العودية ، يتم تطبيق خوارزمية مألوفة على كل نصف مصفوفة - باستخدام نفس الصيغة ، يحدث توزيع تقريبي داخل الطبقة الفرعية ، مع الفرز حسب إدراج الأقسام غير المصنفة المحلية.
- بعد ترتيب نصفي المصفوفات الفرعية ، يندمجان.
- يتم تكرار النقطة 3 (دمج المصفوفات الفرعية للنصف) عند التسلق عبر مستويات العودية إلى الأعلى ، عندما يتم دمج المصفوفة الأصلية من نصفي.
فرز حسب الإدراج التجزئة في جافا import java.util.Arrays; import java.util.Date; import java.util.Random; public class HashSort {
تسمى الصيغة نفسها دالة التجزئة ، وتسمى المصفوفة المساعدة للتوزيع التقريبي بجدول التجزئة.
مراجع
الاستيفاء والرسم البياني ،
فلاش ،
Proxmap
سليمان ،
تجزئة الجدول ،
فلاشسلسلة المقالات:
ظهر فرز التقريب في تطبيق AlgoLab Excel (في هذه الحالة ، في الصفيف الأولي غير المصنف ، يتم إلحاق الجزء الكسري العشوائي بالأعداد الصحيحة). كان سليمان وفلاش موجودين هناك لفترة طويلة ، لكنهما لم يطبقا بعد الاستيفاء والتجزئة والرسم البياني.