• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Quicksort. Jak działa ten algorytm?

Object Storage Arubacloud
0 głosów
586 wizyt
pytanie zadane 19 stycznia 2017 w JavaScript przez ZaXi Nowicjusz (150 p.)
edycja 19 stycznia 2017 przez Arkadiusz Waluk

Może mi ktoś wytłumaczyć jak ten algorytm działa? Krok po kroku smiley

function quicksort(arr) {
 if (arr.length <= 1) {
 return arr;
}

var arrLength = arr.length;
var pivotPosition = Math.floor(arrLength / 2);
var pivotValue = arr[pivotPosition];
var less = [],
    more = [],
    same = [];
for (var i = 0; i < arrLength; i++) {
    if (arr[i] === pivotValue) {
    same.push(arr[i]);
}
    else if (arr[i] < pivotValue) {
    less.push(arr[i]);
 }
    else {
     more.push(arr[i]);
     }
 }
   return quicksort(less).concat(same, quicksort(more));
 }
 quicksort([4,5,2,3,6,7,9,1,8]);

1 odpowiedź

+1 głos
odpowiedź 19 stycznia 2017 przez Jacob99 Obywatel (1,840 p.)
wybrane 19 stycznia 2017 przez ZaXi
 
Najlepsza
function quicksort(arr) {
 if (arr.length <= 1)
{
 return arr;
//Jeżeli tablica ma tylko jeden element 
//lub nie ma elementów, to funkcja zwraca tablicę
}

var arrLength = arr.length;  
//długość tablicy (ilość elementów)
var pivotPosition = Math.floor(arrLength / 2); 
//ustawia środkowy indeks tablicy. 
//Jeśli tablica ma parzystą liczbę elementów
//to zaokrągla do elementu o niższym indeksie
var pivotValue = arr[pivotPosition]; 
// pobiera wartość tablicy dla argumentu pivotPosition
var less = [],  //tworzy tablicę liczb mniejszych od środkowej
    more = [],  //tworzy tablicę liczb większych od środkowej
    same = []; //tworzy tablicę liczb o takiej samej wartości jak środkowa
for (var i = 0; i < arrLength; i++) {
    if (arr[i] == pivotValue) {
    same.push(arr[i]); 
//Jeżeli wartość elementu tablicy 
//jest taka sama jak wartość środkowa,
//to dodaje wartość do tablicy same[]
}
    else if (arr[i] < pivotValue) {
    less.push(arr[i]); 
//Jeżeli wartość elementu tablicy jest mniejsza 
//niż wartość środkowa,
//to dodaje wartość do tablicy less[]
 }
    else {
     more.push(arr[i]); 
//W innym przypadku dodaje wartość do tablicy more[]
     }
 }
   return quicksort(less).concat(same, quicksort(more)); 
//Zwraca posortowaną tablicę
 }

 

Podobne pytania

0 głosów
1 odpowiedź 383 wizyt
pytanie zadane 6 stycznia 2021 w Python przez maciej12 Nowicjusz (120 p.)
0 głosów
1 odpowiedź 483 wizyt
pytanie zadane 23 kwietnia 2020 w C i C++ przez Rrafał98 Nowicjusz (240 p.)
0 głosów
1 odpowiedź 4,723 wizyt

92,539 zapytań

141,382 odpowiedzi

319,476 komentarzy

61,928 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...