基本准备:

  function  CArray(numElems) {
this.dataStore = [];
this.pos = 0;
this.numElems = numElems;
this.insert = insert;
this.toString = toString;
this.clear = clear;
this.setData = setData;
this.swap =swap;
for(var i = 0; i < numElems; ++i) {
this.dataStore[i] = i;
}
}
function setData() {
for(var i = 0; i < this.numElems; ++i) {
this.dataStore[i] = Math.floor(Math.random() * 100);//0-99
}
}
function clear() {
for (var i = 0; i < this.numElems; ++i) {
this.dataStore[i] = 0;
}
}
function insert(elem) {
this.dataStore[this.pos++] = elem;
}
function toString() {
var str = "";
for(var i = 0; i < this.dataStore.length; ++i) {
str += this.dataStore[i] + " ";
if( i > 0 && (i+1) %10 === 0) {
str += "\n";
}
}
return str;
}
function swap(arr,index1,index2) {
var temp = arr[index1];
arr[index1] = arr[index2];
arr[index2] = temp;
}

 基本排序算法:

  • 冒泡排序:最容易实现也是最慢的算法之一

    • 从头开始依次分别比较相邻的两个元素并排序,直到最后一个;此时确定最后一个会是最大的;
    • 重复上面步骤但不比较已经确定的,此时确定最后第二个是第二大的;
    • 继续重复直到剩下第一个元素为止,确定它是最小的;

效果:

  function bubbleSort() {
var numElems = this.dataStore.length;
var temp;
for(var outer = numElems; outer > 1 ; --outer) {
for(var inner = 0; inner < outer; ++inner) {
if(this.dataStore[inner] > this.dataStore[inner + 1]) {
swap(this.dataStore,inner,inner + 1);
}
}
}
}

demo:

  • 选择排序:也是简单的算法之一

    • 从未排序的数列开头开始向后一个个比较,找到一个比它小的值,交互位置;
    • 用刚交互的值从它被替换的位置开始继续向后比较,重复直到比较到最后一个值,此时最前面的值为这次排序找出的最小值,确定它排序;
    • 继续从剩下的未确定排序的数列从头开始重复,找到最小值放到前面第二个个位置,重复;
    • 继续,直到只剩最后一个数值;
    • 效果:

  function selectionSort() {
var min,temp;
for(var outer = 0; outer < this.dataStore.length-1; ++outer) { //不和自己比较减一
min = outer;
for(var inner = outer+1; inner < this.dataStore.length; ++inner) { //和已确定排序的个数叫要比较的一个比较
if(this.dataStore[inner] < this.dataStore[min]) {
swap(this.dataStore,inner,min);
}
}
}
}

demo:

  • 插入排序:也是简单的算法之一,特别是在对已经排好序的数据操作时效率高;

    • 开头的第一个元素为确定排序,从第二个元素开始,在确定的排序数列中从后往前比较;
    • 如果大于被比较的数值,则插入其后面,反之则继续往前比较;
    • 当第二个元素插入到适当位置后,第三个元素继续重复;
    • 继续,直到最后一个元素;
    • 效果:

 function insertionSort() {
var temp,inner;
for(var outer = 1; outer < this.dataStore.length; ++outer) {
temp = this.dataStore[outer];
inner = outer;
while(inner > 0 && (this.dataStore[inner - 1] > temp)) {
this.dataStore[inner] = this.dataStore[inner - 1]; //这里不是单纯的交互,不用swap
--inner;
}
this.dataStore[inner] = temp;
}
}

demo:

一般来讲三种算法速度:插入>选择>冒泡;

js:数据结构笔记11--排序算法(1)的更多相关文章

  1. js:数据结构笔记12--排序算法(2)

    高级排序算法:(处理大数据:百万以上) 希尔排序:是插入排序的优化版: 首先设置间隔数组,然后按照每个间隔,分别进行排序: 如第一个间隔为5,首先a[5]与a[0]进行插入排序;然后a[6]和a[0] ...

  2. js:数据结构笔记13--检索算法

    顺序查找:也称线性查找,暴力查找的一种 基本格式: var nums = []; for(var i = 0; i < 10; ++i) { nums[i] = Math.floor(Math. ...

  3. js学习笔记之排序算法的原理及代码

    冒泡排序 比较任何两个相邻的项,如果第一个比第二个大,则交换它们 重复这样的操作,直到排序完成,具体代码如下: let arr = [67,23,11,89,45,76,56,99] function ...

  4. js:数据结构笔记14--高级算法

    动态规划: 递归是从顶部开始将问题分解,通过解决所有分解出小问题来解决整体问题: 动态规划从底部开始解决问题,将所有小问题解决,然后合并掉一个整体解决方案: function dynFib(n) { ...

  5. 使用 js 实现十大排序算法: 堆排序

    使用 js 实现十大排序算法: 堆排序 堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法. 大顶堆:每个节点的值都大于或等于其子节点的值,在堆排序算法中用于升序排列: 小顶堆:每个 ...

  6. Java基础复习笔记基本排序算法

    Java基础复习笔记基本排序算法 1. 排序 排序是一个历来都是很多算法家热衷的领域,到现在还有很多数学家兼计算机专家还在研究.而排序是计算机程序开发中常用的一种操作.为何需要排序呢.我们在所有的系统 ...

  7. 使用 js 实现十大排序算法: 快速排序

    使用 js 实现十大排序算法: 快速排序 QuickSort 快速排序 /** * * @author xgqfrms * @license MIT * @copyright xgqfrms * @c ...

  8. 使用 js 实现十大排序算法: 桶排序

    使用 js 实现十大排序算法: 桶排序 桶排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  9. 使用 js 实现十大排序算法: 计数排序

    使用 js 实现十大排序算法: 计数排序 计数排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

随机推荐

  1. POJ 1260 Pearls

    Pearls Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 6670 Accepted: 3248 Description In ...

  2. 如何让ThinkPHP的模板引擎达到最佳效率

    默认情况下ThinkPHP框架系统默认使用的模板引擎是内置模板引擎.内置模板引擎支持模板文件中采用php原生态代码和模板标签的混合使用.ThinkPHP官方开发文档说,这种默认的内置模板引擎的性能是高 ...

  3. More is better(MST)(求无向图中最大集合元素个数)

    More is better Time Limit:1000MS     Memory Limit:102400KB     64bit IO Format:%I64d & %I64u Sub ...

  4. [Effective JavaScript 笔记] 第11条:熟练掌握闭包

    理解闭包三个基本的事实 第一个事实:js允许你引用在当前函数以外定义的变量. function makeSandwich(){ var magicIngredient=”peanut butter”; ...

  5. 安装 openSUSE Leap 42.1 之后要做的 8 件事

    导读 openSUSE Leap 确实是个巨大的飞跃,它允许用户运行一个和 SUSE Linux 企业版拥有同样基因的发行版.和其它系统一样,为了实现最佳的使用效果,在使用它之前需要做些优化设置. 下 ...

  6. php substr中文乱码最有效到解决办法 转:http://blog.sina.com.cn/s/blog_49b531af0100esah.html

    (2009-07-29 12:29:38) 转载▼ 标签: php substr文乱码 网站开发 it   直接使用PHP函数substr截取中文字符可能会出现乱码,主要是substr可能硬生生的将一 ...

  7. WPF 布局总结

    一.WPF布局原理 WPF窗口只能包含单个元素,为在WPF窗口中放置多个元素,需要放置一个容器,让后在容器中添加其他元素.“理想的”WPF窗口需遵循以下几个原则: 1.不应显示设定元素的尺寸.元素应当 ...

  8. ICA

    参考:http://www.cnblogs.com/jerrylead/archive/2011/04/19/2021071.html 对高斯分布的样本点效果不好.数学真是博大精深啊

  9. IOC原理解释

    spring ioc它其实是一种降低对象耦合关系的设计思想,通常来说,我们在一个类调用另一个类的方法的时候,需要不断的new新的对象来调用该方法,类与类之间耦合度比较高,有了ioc容器以后,ico容器 ...

  10. python下的MySQLdb使用

    下载安装MySQLdb <1>linux版本 http://sourceforge.net/projects/mysql-python/ 下载,在安装是要先安装setuptools,然后在 ...