javascript数据结构与算法--高级排序算法(快速排序法,希尔排序法)
javascript数据结构与算法--高级排序算法(快速排序法,希尔排序法)
一、快速排序算法
- /*
- * 这个函数首先检查数组的长度是否为0。如果是,那么这个数组就不需要任何排序,函数直接返回。
- * 否则,创建两个数组,一个用来存放比基准值小的元素,另一个用来存放比基准值大的元素。
- * 这里的基准值取自数组的第一个元素。
- * 接下来,这个函数对原始数组的元素进行遍历,根据它们与基准值的关系将它们放到合适的数组中。
- * 然后对于较小的数组和较大的数组分别递归调用这个函数。
- * 当递归结束时,再将较大的数组和较小的数组连接起来,形成最终的有序数组并将结果返回。
- * */
- function qSort(arr){
- if (arr.length == 0) {
- return [];
- }
- var left = [];//存储小于基准值
- var right = [];//存储大于基准值
- var pivot = arr[0];
- for (var i = 1; i < arr.length; i++) {
- if (arr[i] < pivot) {
- left.push(arr[i]);
- } else {
- right.push(arr[i]);
- }
- }
- return qSort(left).concat(pivot, qSort(right));
- }
- var a = [];
- for (var i = 0; i < 10; ++i) {
- a[i] = Math.floor((Math.random()*100)+1);
- }
- //console.log(a);
- console.log("排序前: "+a);
- console.log("排序后: "+qSort(a));
二、希尔排序算法
- function CArray(numElements,gaps) {
- this.dataStore = [];
- this.pos = 0;//是一个索引值,默认为0,从第一个开始
- this.numElements = numElements;//是保存所有的数组元素
- this.insert = insert;//向数组中插入一个元素的方法
- this.toString = toString;//显示数组中所有元素
- this.clear = clear;//清空数组数据
- this.setData = setData;//生成了存储在数组中的随机数字
- this.gaps = gaps;//定义间隔序列
- this.shellSort = shellSort;//希尔排序
- /*将传入的数组,存储在datastore中*/
- for (var i = 0; i < numElements.length; ++i) {
- this.dataStore[i] = numElements[i];
- }
- }
- function setData() {
- for (var i = 0; i < this.numElements; ++i) {
- this.dataStore[i] = Math.floor(Math.random() *
- (this.numElements+1));
- }
- }
- function clear() {
- for (var i = 0; i < this.dataStore.length; ++i) {
- this.dataStore[i] = 0;
- }
- }
- function insert(element) {
- this.dataStore[this.pos++] = element;
- }
- function toString() {
- var retstr = "";
- for (var i = 0; i < this.dataStore.length; ++i) {
- retstr += this.dataStore[i] + " ";
- if (i > 0 && i % 10 == 0) {
- retstr += "\n";
- }
- }
- return retstr;
- }
- /*
- * 外循环控制间隔序列的移动。也就是说,算法在第一次处理数据集时,会检查所有间隔为5的元素。
- * 下一次遍历会检查所有间隔为3的元素。
- * 最后一次则会对间隔为1的元素,也就是相邻元素执行标准插入排序。
- * 在开始做最后一次处理时,大部分元素都将在正确的位置,算法就不必对很多元素进行交换。
- * 这就是希尔排序比插入排序更高效的地方。
- * */
- function shellSort() {
- console.log("排序前"+": "+myNums.toString());
- for(var g = 0; g < this.gaps.length; ++g) {
- for(var i = this.gaps[g]; i < this.dataStore.length; ++i) {
- var temp = this.dataStore[i];
- for(var j = i; j >= this.gaps[g] && this.dataStore[j - this.gaps[g]] > temp; j -= this.gaps[g]) {
- this.dataStore[j] = this.dataStore[j - this.gaps[g]];
- }
- this.dataStore[j] = temp;
- // console.log(g+"--"+i+": "+myNums.toString());
- }
- console.log(g+": "+myNums.toString());
- }
- }
- // 希尔排序测试代码
- var numElements = [0,9,1,8,7,6,2,3,5,4];
- var gaps = [3,2,1];
- var myNums = new CArray(numElements,gaps);
- myNums.shellSort();
- console.log("排序后"+": "+myNums.toString());
javascript数据结构与算法--高级排序算法(快速排序法,希尔排序法)的更多相关文章
- JavaScript 数据结构与算法之美 - 归并排序、快速排序、希尔排序、堆排序
1. 前言 算法为王. 想学好前端,先练好内功,只有内功深厚者,前端之路才会走得更远. 笔者写的 JavaScript 数据结构与算法之美 系列用的语言是 JavaScript ,旨在入门数据结构与算 ...
- C# 插入排序 冒泡排序 选择排序 高速排序 堆排序 归并排序 基数排序 希尔排序
C# 插入排序 冒泡排序 选择排序 高速排序 堆排序 归并排序 基数排序 希尔排序 以下列出了数据结构与算法的八种基本排序:插入排序 冒泡排序 选择排序 高速排序 堆排序 归并排序 基数排序 希尔排序 ...
- php 实现冒泡算法排序、快速排序、选择排序,插入排序
许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣.作为一个初级phper,虽然很少接触到算法方面的东西 .但是对于冒泡排序,插入排序,选择排序,快速排序四种基本算法,我想还是要 ...
- 数据结构与算法之排序(4)希尔排序 ——in dart
研究了网上大部分的希尔排序代码,发现大部分都是互相抄的——因为网上甚至某些书上的实现大部分都是错的.希尔排序是插入排序的升级版,通过引入间隔,然后分组进行插入排序.再逐步缩小间隔,直至间隔为1时,做全 ...
- 数据结构与算法-排序(七)希尔排序(Shell Sort)
摘要 看希尔排序需要先想象出一个二维的矩阵,在这个矩阵中,有多少列数据全看步长(一定的规则得到).处理完之后,就再接着用另一个步长组成矩阵处理.直到步长全部使用完. 这里的巧妙之处就是没有把序列先处理 ...
- python实现排序算法 时间复杂度、稳定性分析 冒泡排序、选择排序、插入排序、希尔排序
说到排序算法,就不得不提时间复杂度和稳定性! 其实一直对稳定性不是很理解,今天研究python实现排序算法的时候突然有了新的体会,一定要记录下来 稳定性: 稳定性指的是 当排序碰到两个相等数的时候,他 ...
- java算法----排序----(6)希尔排序(最小增量排序)
package log; public class Test4 { /** * java算法---希尔排序(最小增量排序) * * @param args */ public static void ...
- Java冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序
冒泡排序 冒泡排序是一种简单的排序算法.它重复地走访过要排序地数列,一次比较两个元素,如果它们地顺序错误就把它们交换过来.走访数列地工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成. ...
- Java数据结构和算法(三):常用排序算法与经典题型
常用的八种排序算法 1.直接插入排序 我们经常会到这样一类排序问题:把新的数据插入到已经排好的数据列中.将第一个数和第二个数排序,然后构成一个有序序列将第三个数插入进去,构成一个新的有序序列.对第四个 ...
- JS实现常用排序算法—经典的轮子值得再造
关于排序算法的博客何止千千万了,也不多一个轮子,那我就斗胆粗制滥造个轮子吧!下面的排序算法未作说明默认是从小到大排序. 1.快速排序2.归并排序3.冒泡排序4.选择排序(简单选择排序)5.插入排序(直 ...
随机推荐
- C语言程序设计50例(三)(经典收藏)
[程序31]题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续 判断第二个字母.1.程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语句判断第二个字母. ...
- excel怎样添加的选项卡中含有下拉列表
<customUI xmlns="http://schemas.microsoft.com/office/2006/01/customui"> <ribbon s ...
- Gym-101102-K-Topological Sort
K. Topological Sort 题面 Consider a directed graph G of N nodes and all edges (u→v) such that u < v ...
- Codeforces Round#415 Div.2
A. Straight «A» 题面 Noora is a student of one famous high school. It's her final year in school - she ...
- (求凹包) Bicycle Race (CF 659D) 简单题
http://codeforces.com/contest/659/problem/D Maria participates in a bicycle race. The speedway t ...
- 网络timeout区分
ConnectTimeout 连接建立时间,三次握手完成时间 SocketTimeout 数据传输过程中数据包之间间隔的最大时间 下面重点说下SocketTimeout,比如有如下图所示的http请求 ...
- MySQL性能优化之延迟关联
[背景] 某业务数据库load 报警异常,cpu usr 达到30-40 ,居高不下.使用工具查看数据库正在执行的sql ,排在前面的大部分是: SELECT id, cu_id, name, in ...
- nodejs mongodb 数据库封装DB类 -转
使用到了nodejs的插件mongoose,用mongoose操作mongodb其实蛮方便的. 关于mongoose的安装就是 npm install -g mongoose 这个DB类的数据库配置是 ...
- Verilog 99题之001-009
001. 画出CMOS反相器的电路原理图. 衬底的连接问题.PMOS衬底接电源,NMOS衬底接地 002. 反相器的速度与哪些因素有关?什么是转换时间(transition time)和传播延迟(pr ...
- Codeforces Round #265 (Div. 2) D. Restore Cube 立方体判断
http://codeforces.com/contest/465/problem/D 给定8个点坐标,对于每个点来说,可以随意交换x,y,z坐标的数值.问说8个点是否可以组成立方体. 暴力枚举即可, ...