Resetting...
This commit is contained in:
70
.vim/vimwiki/vimwiki_html/Quicksort.html
Normal file
70
.vim/vimwiki/vimwiki_html/Quicksort.html
Normal file
@@ -0,0 +1,70 @@
|
||||
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
|
||||
<html>
|
||||
<head>
|
||||
<link rel="Stylesheet" type="text/css" href="style.css">
|
||||
<title>Quicksort</title>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<h2 id="toc_0.1">Quicksort</h2>
|
||||
<dl>
|
||||
<dt>Stats</dt>
|
||||
<dd>Worst Case Performance: O(n<sup><small>2</small></sup>)</dd>
|
||||
<dd>Best Case Performance: O(n log n)</dd>
|
||||
</dl>
|
||||
|
||||
<h3 id="toc_0.1.1">Algorithm</h3>
|
||||
<ol>
|
||||
<li>
|
||||
Pick an element, called a <strong>pivot</strong>, from the list.
|
||||
|
||||
<li>
|
||||
Make three lists:
|
||||
|
||||
<ul>
|
||||
<li>
|
||||
before: all elements smaller than pivot
|
||||
|
||||
<li>
|
||||
pivot: all elements equal to pivot
|
||||
|
||||
<li>
|
||||
after: all elements larger than pivot
|
||||
|
||||
</ul>
|
||||
<li>
|
||||
recurse on before-list and after-list, then return concat(before, pivot, after)
|
||||
|
||||
</ol>
|
||||
|
||||
<h3 id="toc_0.1.2">Psuedocode</h3>
|
||||
<pre>
|
||||
function quicksort(items) {
|
||||
if(count(items) <= 1) {
|
||||
return a
|
||||
}
|
||||
middle_idx = count(items)/2;
|
||||
pivot = [];
|
||||
pivot[] = items[middle_idx];
|
||||
before_list = after_list = [];
|
||||
for(i in items) {
|
||||
if(items[i] < pivot) {
|
||||
before_list[] = items[i];
|
||||
} else if(items[i] > pivot) {
|
||||
after_list[] = items[i];
|
||||
} else {
|
||||
pivot[] = items[i];
|
||||
}
|
||||
}
|
||||
return concatenate(quicksort(before_list), pivot, quicksort(after_list));
|
||||
}
|
||||
</pre>
|
||||
|
||||
<h3 id="toc_0.1.3">Additional Info</h3>
|
||||
<p>
|
||||
Wikipedia Article [<a href="http://en.wikipedia.org/wiki/Quicksort]">http://en.wikipedia.org/wiki/Quicksort]</a>
|
||||
</p>
|
||||
|
||||
</body>
|
||||
</html>
|
Reference in New Issue
Block a user