Heim > Web-Frontend > js-Tutorial > Javascript-Sortieralgorithmus, der Sortierbeispiele zählt_Javascript-Kenntnisse

Javascript-Sortieralgorithmus, der Sortierbeispiele zählt_Javascript-Kenntnisse

WBOY
Freigeben: 2016-05-16 16:53:07
Original
1269 Leute haben es durchsucht

Counting Sort ist ein stabiler Sortieralgorithmus. Die Zählsortierung verwendet ein zusätzliches Array Count_arr, wobei das i-te Element die Anzahl der Elemente ist, deren Wert gleich i im zu sortierenden Array Arr ist. Ordnen Sie dann die Elemente in Arr entsprechend dem Array Count_arr an der richtigen Position an.
ist in vier Schritte unterteilt:
1. Finden Sie die größten und kleinsten Elemente im Array, die sortiert werden sollen.
2. Zählen Sie die Anzahl der Vorkommen jedes Elements mit dem Wert i im Array und speichern Sie es im array Count_arr Item i
3. Akkumulieren Sie alle Zählungen (beginnen Sie mit dem ersten Element in Count_arr und fügen Sie jedes Element zum vorherigen Element hinzu)
4. Durchlaufen Sie das ursprüngliche Array in umgekehrter Reihenfolge: Fügen Sie jedes Element i hinzu (i) Element des neuen Arrays und subtrahiere Count_arr(i) um 1 für jedes Element

Beispiel:

Code kopieren Der Code lautet wie folgt:

/**
* Counting Sort ist ein nicht vergleichsbasierter Sortieralgorithmus.
* Dieser Algorithmus wurde 1954 von Harold H. Seward vorgeschlagen.
* Sein Vorteil besteht darin, dass beim Sortieren von Ganzzahlen innerhalb eines bestimmten Bereichs
* Seine Komplexität Ο(n k) beträgt (wobei k der Bereich der Ganzzahlen ist),
* Schneller als jeder Vergleichssortierungsalgorithmus.
*
*/

function countSort(arr, min, max) {
var i , z = 0, count = [];

for (i = min; i <= max; i ) {
count[i] = 0;
}

for (i=0; i < arr.length; i ) {
count[arr[i]] ;
}

for (i = min; i <= max; i ) {
while (count[i]-- > 0) {
arr[z ] = i;
}
}
return arr;
}

// test

var i, arr = [];

for (i = 0; i < 100; i ) {
arr.push(Math.floor (Math .random() * (141)));
}

countSort(arr, 0, 140);
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage