Html5 快速排序演示

快速排序(Quicksort)是对冒泡排序的一种改进。快速排序由C. A. R. Hoare在1962年提出。

  • 它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列
  • 快速排序不是一种稳定的排序算法,也就是说,多个相同的值的相对位置也许会在算法结束时产生变动。
  • 每次尽可能地选择一个能够代表中值的元素作为关键数据,然后遵循普通快排的原则进行比较、替换和递归。
  • 快速排序的平均运行时间为O(nlogn)。

-----------------------------------------------------------------------------------------------------------------------------------------

演示如下图所示:

算法原理不再赘述,具体代码如下:

  1 <!DOCTYPE html>
  2 <html>
  3 <head>
  4     <title>The twelve html page</title>
  5 <style type="text/css">
  6         ul li
  7         {
  8             list-style-type:georgian;
  9             text-align:left;
 10          }
 11         .mark
 12         {
 13             width:180px;
 14             height:40px;
 15             color:Olive;
 16             text-align:center;
 17             line-height:40px;
 18             margin:5px;
 19             float:left;
 20          }
 21           .redball
 22         {
 23             width:40px;
 24             height:40px;
 25             border-radius:20px;
 26             background-color:Red;
 27             text-align:center;
 28             line-height:40px;
 29             margin:5px;
 30             float:left;
 31         }
 32         .ball
 33         {
 34             width:40px;
 35             height:40px;
 36             border-radius:20px;
 37             background-color:Aqua;
 38             text-align:center;
 39             line-height:40px;
 40             margin:5px;
 41             float:left;
 42         }
 43         .line
 44         {
 45             clear:left;
 46          }
 47         header
 48         {
 49             height:80px;
 50             border:1px solid gray;
 51         }
 52         .left
 53         {
 54             border:1px solid gray;
 55             float:left;
 56             width:30%;
 57             height:480px;
 58             margin-left:0px;
 59             margin-right:0px;
 60
 61         }
 62         aside
 63         {
 64             text-align:center;
 65         }
 66         section
 67         {
 68             width:69.5%;
 69             float:left;
 70             height:480px;
 71             border:1px solid gray;
 72             margin-left:0px;
 73             margin-right:0px;
 74         }
 75         footer
 76         {
 77             clear:left;
 78             height:60px;
 79             border:1px solid gray;
 80         }
 81         input[type="button"]
 82         {
 83             width:80px;
 84             text-align:center;
 85             margin-top:10px;
 86          }
 87     </style>
 88     <script type="text/javascript">
 89         function initDiv() {
 90             var mainArea = document.getElementById("mainArea");
 91             for (var i = 0; i < 8; i++) {
 92                 var newDivLine = document.createElement("div");
 93                 newDivLine.setAttribute("class", "line");
 94                 mainArea.appendChild(newDivLine);
 95                 for (var j = 0; j < 9; j++) {
 96                     var newDiv = document.createElement("div");
 97                     var id = i.toString() + j.toString();
 98                     newDiv.setAttribute("id", id);
 99                     if (j < 8) {
100                         newDiv.setAttribute("class", "ball");
101                     } else {
102                         newDiv.setAttribute("class", "mark");
103                     }
104                     newDivLine.appendChild(newDiv);
105                 }
106             }
107         }
108
109         function setElementsValue() {
110             var arrTmp = [4, 6, 8, 7, 9, 2, 10, 1];//初始元素赋值
111             for (var i = 0; i < arrTmp.length; i++) {
112                 document.getElementById("0" + i.toString()).innerText = arrTmp[i];
113             }
114             document.getElementById("08").innerText = "原始数据";
115         }
116         var m = 0; //表示第几趟排序
117         //快速排序
118         function setQuickSortValue() {
119             m = 0;
120             var arrTmp = [4, 6, 8, 7, 9, 2, 10, 1];
121             QuickSort(arrTmp,0,arrTmp.length-1);
122         }
123         function QuickSort(arrTmp, low, high) {
124             if (low >= high) {
125                 return;
126             }
127             //完成一次单元排序
128             var index = QuickSortUnit(arrTmp, low, high);
129
130             //对左边进行排序
131             QuickSort(arrTmp, low, index - 1);
132             //对右边进行排序
133             QuickSort(arrTmp, index + 1, high);
134         }
135
136         //快速排序单元
137         function QuickSortUnit(arrTmp, low, high) {
138             var key = arrTmp[low];
139             while (low < high) {
140                 //从后向前搜索比key小的值
141                 while (arrTmp[high] >= key && high > low) {
142                     --high;
143                 }
144                 //比key小的放左边
145                 arrTmp[low] = arrTmp[high];
146                 while (arrTmp[low] <= key && high > low) {
147                     ++low;
148                 }
149                 arrTmp[high] = arrTmp[low];
150             }
151             arrTmp[low] = key;
152             m = m + 1;
153             ShowHtml(arrTmp, m, high);
154             return high;
155         }
156
157         //m表示第几趟排序,index表示分组的分界线
158         function ShowHtml(arrTmp,m,index) {
159             //显示出来
160             for (var k = 0; k < arrTmp.length; k++) {
161                 document.getElementById((m).toString() + k.toString()).innerText = arrTmp[k];
162                 if (index == k) {
163                     document.getElementById((m).toString() + (k).toString()).setAttribute("class", "redball");
164                 }
165             }
166             document.getElementById((m).toString() + "8").innerText += "第 " + (m).toString() + " 趟排序(index="+index+")";
167         }
168
169     </script>
170 </head>
171 <body>
172 <header>
173     <h1>快速排序(Quick Sort)Demo</h1>
174 </header>
175 <aside class="left">
176
177 <input type="button" id="btnInit" value="Init" onclick="initDiv();" />
178 <br />
179 <input type="button" id="btnSetValue" value="SetValue" onclick="setElementsValue();" />
180 <br />
181 <input type="button" id="btnSort" value="Quick Sort" onclick="setQuickSortValue();" />
182 <br />
183 <h3>快速排序(Quick Sort)</h3>
184 <ul>
185     <li>快速排序(Quicksort)是对冒泡排序的一种改进。<mark>交换排序</mark></li>
186     <li>快速排序是<mark>非稳定</mark>排序算法,也就是说,多个相同的值的相对位置也许会在算法结束时产生变动。</li>
187     <li>基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以<mark>递归</mark>进行,以此达到整个数据变成有序序列。</li>
188     <li>设要排序的数组是A[0]……A[N-1],首先任意选取一个数据(通常选用数组的第一个数)作为关键数据,然后将所有比它小的数都放到它前面,所有比它大的数都放到它后面,这个过程称为一趟快速排序。</li>
189     <li>快速排序的平均运行时间为O(nlogn)。</li>
190 </ul>
191 </aside>
192 <section id="mainArea">
193
194 </section>
195 <footer>
196     这是底部信息
197 </footer>
198 </body>
199 </html>

快速排序算法,优化方案:

  1. 三平均分区法,将待排序的数据分为前,中,后 三个区
  2. 根据分区大小调整算法,因为快速排序算法对于数据较少时并没有优势
  3. 并行的分区快速排序,由于快速排序算法是采用分治技术来进行实现的,这就使得它很容易能够在多台处理机上并行处理。
时间: 2025-01-02 00:01:36

Html5 快速排序演示的相关文章

超酷创意HTML5动画演示及代码

HTML5是未来的网页开发神器,今天分享的这些HTML5动画大部分利用了CSS3的动画属性来实现,废话不多说,直接上演示和代码. HTML5/CSS3实现大风车旋转动画 这次我们要来分享一款很酷的HTML5动画,是一个可以旋转的大风车动画效果,回顾一下利用HTML5实现的旋转动画,我们可以看HTML5/CSS3实现3D旋转陀螺动画,它们的实现都是利用CSS3的transform:rotate属性,这款大风车动画的确比较厉害的. 在线演示        源码下载 用HTML5/CSS3给女朋友送个

LEADTOOLS HTML5 Demos演示汇总

LEADTOOLS HTML5/JavaScript Demo系列展示了LEADTOOLS的部分特色功能,包含扩展的文件格式支持(TIFF,GIF,JPEG2000,JPEG等).自动标注.图像处理.条码识别.OCR和DICOM图像显示等.由于LEADTOOLS HTML5/JavaScript包含在LEADTOOLS Imaging SDK 中,若需LEADTOOLS HTML5 Demos源代码,请下载>>>LEADTOOLS Imaging SDK >>>查看所有

Html5 冒泡排序演示

冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法. 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成. 这个算法的名字由来是因为越大的元素会经由交换慢慢"浮"到数列的顶端,故名. ------------------------------------------------------------------------ 本例是用Html展示,冒泡排序的

惊艳的HTML5动画特效及源码

今天我们要来分享一些很酷的HTML5动画演示,HTML5的强大之处在于它可以利用canvas的特性来绘制很多普通网页无法完成的图形和动画,canvas就像一块超级画板,在上面不仅可以实现平面图形,而且一些3D动画也非常简单.很多HTML5动画也都基于canvas,一起来看看吧. HTML5/CSS3实现大风车旋转动画 作为今天首款HTML5动画,这款大风车旋转效果的确非常棒,它是用纯CSS3实现. 核心CSS代码: .wmd1{ -webkit-transform: scale(.6); pos

6.5 快速排序

(1)快速排序: 快速排序(英语:Quicksort),又称划分交换排序(partition-exchange sort),通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列. 步骤为: 1.从数列中挑出一个元素,称为"基准"(pivot), 2.重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数

小白初识 - 快速排序(QuickSort)

我个人觉得快速排序和归并排序有相似之处,都是用到了分治的思想,将大问题拆分成若干个小问题. 不同的地方是归并排序是先把大问题拆分好了之后再排序,而快速排序则是一边拆分,一边排序. 快速排序的原理就是,针对一个数组,我们任意选取数组中的一个数,将数组中的数与它一一比较,如果小于它呢,就放左边, 大于它呢,就放右边.再针对左边和右边的重复上述动作即可,所以也要用到递归. 先来看看递归公式:quickSort(p...r) = quickSort(p...q-1) + quickSort(q+1, r

ActiveReports 报表控件官方中文新手教程 (1)-安装、激活以及产品资源

?? 本系列文章主要是面向初次接触 ActiveReports 产品的用户,能够帮助您在三天之内轻松的掌握ActiveReports控件的基本用法,包含安装.激活.创建报表.绑定数据源以及公布等内容.本篇文章我们就从安装产品開始带您开启轻松的 ActiveReports 体验之旅. 系列文章列表: ActiveReports 报表控件官方中文新手教程 (2)-创建.数据源.浏览以及公布 ActiveReports 报表控件官方中文新手教程 (3)-怎样选择页面报表和区域报表 本文内容包含: 安装

javascript开源大全

javascript开源大全 Ajax框架-jQuery 可视化HTML编辑器-CKEditor 国产jQuery-UI框架-(jUI)-DWZ 网页开发FireFox插件-Firebug 服务器端的JavaScript脚本-Node.js jQuery图表插件-jQchart HTML5-开发框架-jQuery-Mobile 跨浏览器的RIA框架-ExtJS Flash视频播放器-JW-PLAYER jQuery表单插件-jQuery.form jQuery-File-Upload 可视化HT

Java常用工具类集合

数据库连接工具类 仅仅获得连接对象 ConnDB.java package com.util; import java.sql.Connection; import java.sql.DriverManager; /** * 数据库连接工具类——仅仅获得连接对象 * */ public class ConnDB { private static Connection conn = null; private static final String DRIVER_NAME = "com.mysql