The Algorithm Design Manual Second Edition


Quicksort: Sorting by Randomization



Download 5,51 Mb.
Pdf ko'rish
bet111/488
Sana31.12.2021
Hajmi5,51 Mb.
#273936
1   ...   107   108   109   110   111   112   113   114   ...   488
Bog'liq
2008 Book TheAlgorithmDesignManual

4.6

Quicksort: Sorting by Randomization

Suppose we select a random item from the items we seek to sort. Quicksort

(shown in action in Figure

4.5


) separates the n

− 1 other items into two piles: a

low pile containing all the elements that appear before in sorted order and a

high pile containing all the elements that appear after in sorted order. Low and

high denote the array positions we place the respective piles, leaving a single slot

between them for p.

Such partitioning buys us two things. First, the pivot element ends up in

the exact array position it will reside in the the final sorted order. Second, after

partitioning no element flops to the other side in the final sorted order. Thus we



can now sort the elements to the left and the right of the pivot independently! This

gives us a recursive sorting algorithm, since we can use the partitioning approach to

sort each subproblem. The algorithm must be correct since each element ultimately

ends up in the proper position:




124

4 .


S O R T I N G A N D S E A R C H I N G

Q  U  I  C  K  S  O  R  T

Q  I  C  K  S  O  R  T  U

Q  I  C  K  O  R  S  T  U

I  C  K  O  Q  R  S  T  U

I  C  K  O  Q  R  S  T  U

C  I  K  O  Q  R  S  T  U

Figure 4.5: Animation of quicksort in action

quicksort(item_type s[], int l, int h)

{

int p;



/* index of partition */

if ((h-l)>0) {

p = partition(s,l,h);

quicksort(s,l,p-1);

quicksort(s,p+1,h);

}

}



We can partition the array in one linear scan for a particular pivot element

by maintaining three sections of the array: less than the pivot (to the left of

firsthigh), greater than or equal to the pivot (between firsthigh and i), and

unexplored (to the right of i), as implemented below:

int partition(item_type s[], int l, int h)

{

int i;



/* counter */

int p;


/* pivot element index */

int firsthigh;

/* divider position for pivot element */

p = h;


firsthigh = l;

for (i=l; i

if (s[i] < s[p]) {

swap(&s[i],&s[firsthigh]);

firsthigh ++;

}

swap(&s[p],&s[firsthigh]);



return(firsthigh);

}



4 . 6

Q U I C K S O R T : S O R T I N G B Y R A N D O M I Z A T I O N



125

Figure 4.6: The best-case (l) and worst-case (r) recursion trees for quicksort

Since the partitioning step consists of at most swaps, it takes linear time in the

number of keys. But how long does the entire quicksort take? As with mergesort,

quicksort builds a recursion tree of nested subranges of the n-element array. As with

mergesort, quicksort spends linear time processing (now partitioning instead of

mergeing) the elements in each subarray on each level. As with mergesort, quicksort

runs in O(n



· h) time, where is the height of the recursion tree.

The difficulty is that the height of the tree depends upon where the pivot

element ends up in each partition. If we get very lucky and happen to repeatedly

pick the median element as our pivot, the subproblems are always half the size

of the previous level. The height represents the number of times we can halve n

until we get down to 1, or at most



lg

2

n



. This happy situation is shown in Figure

4.6


(l), and corresponds to the best case of quicksort.

Now suppose we consistently get unlucky, and our pivot element always splits

the array as unequally as possible. This implies that the pivot element is always

the biggest or smallest element in the sub-array. After this pivot settles into its

position, we are left with one subproblem of size n

− 1. We spent linear work and

reduced the size of our problem by one measly element, as shown in Figure

4.6

(r).


It takes a tree of height n

− 1 to chop our array down to one element per level, for

a worst case time of Θ(n

2

).

Thus, the worst case for quicksort is worse than heapsort or mergesort. To



justify its name, quicksort had better be good in the average case. Understanding

why requires some intuition about random sampling.




Download 5,51 Mb.

Do'stlaringiz bilan baham:
1   ...   107   108   109   110   111   112   113   114   ...   488




Ma'lumotlar bazasi mualliflik huquqi bilan himoyalangan ©hozir.org 2024
ma'muriyatiga murojaat qiling

kiriting | ro'yxatdan o'tish
    Bosh sahifa
юртда тантана
Боғда битган
Бугун юртда
Эшитганлар жилманглар
Эшитмадим деманглар
битган бодомлар
Yangiariq tumani
qitish marakazi
Raqamli texnologiyalar
ilishida muhokamadan
tasdiqqa tavsiya
tavsiya etilgan
iqtisodiyot kafedrasi
steiermarkischen landesregierung
asarlaringizni yuboring
o'zingizning asarlaringizni
Iltimos faqat
faqat o'zingizning
steierm rkischen
landesregierung fachabteilung
rkischen landesregierung
hamshira loyihasi
loyihasi mavsum
faolyatining oqibatlari
asosiy adabiyotlar
fakulteti ahborot
ahborot havfsizligi
havfsizligi kafedrasi
fanidan bo’yicha
fakulteti iqtisodiyot
boshqaruv fakulteti
chiqarishda boshqaruv
ishlab chiqarishda
iqtisodiyot fakultet
multiservis tarmoqlari
fanidan asosiy
Uzbek fanidan
mavzulari potok
asosidagi multiservis
'aliyyil a'ziym
billahil 'aliyyil
illaa billahil
quvvata illaa
falah' deganida
Kompyuter savodxonligi
bo’yicha mustaqil
'alal falah'
Hayya 'alal
'alas soloh
Hayya 'alas
mavsum boyicha


yuklab olish