js:数据结构笔记11--排序算法(1)
基本准备:
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);
}
}
}
}
- 选择排序:也是简单的算法之一
- 从未排序的数列开头开始向后一个个比较,找到一个比它小的值,交互位置;
- 用刚交互的值从它被替换的位置开始继续向后比较,重复直到比较到最后一个值,此时最前面的值为这次排序找出的最小值,确定它排序;
- 继续从剩下的未确定排序的数列从头开始重复,找到最小值放到前面第二个个位置,重复;
- 继续,直到只剩最后一个数值;
- 效果:
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);
}
}
}
}
- 插入排序:也是简单的算法之一,特别是在对已经排好序的数据操作时效率高;
- 开头的第一个元素为确定排序,从第二个元素开始,在确定的排序数列中从后往前比较;
- 如果大于被比较的数值,则插入其后面,反之则继续往前比较;
- 当第二个元素插入到适当位置后,第三个元素继续重复;
- 继续,直到最后一个元素;
- 效果:
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;
}
}
一般来讲三种算法速度:插入>选择>冒泡;
js:数据结构笔记11--排序算法(1)的更多相关文章
- js:数据结构笔记12--排序算法(2)
高级排序算法:(处理大数据:百万以上) 希尔排序:是插入排序的优化版: 首先设置间隔数组,然后按照每个间隔,分别进行排序: 如第一个间隔为5,首先a[5]与a[0]进行插入排序;然后a[6]和a[0] ...
- js:数据结构笔记13--检索算法
顺序查找:也称线性查找,暴力查找的一种 基本格式: var nums = []; for(var i = 0; i < 10; ++i) { nums[i] = Math.floor(Math. ...
- js学习笔记之排序算法的原理及代码
冒泡排序 比较任何两个相邻的项,如果第一个比第二个大,则交换它们 重复这样的操作,直到排序完成,具体代码如下: let arr = [67,23,11,89,45,76,56,99] function ...
- js:数据结构笔记14--高级算法
动态规划: 递归是从顶部开始将问题分解,通过解决所有分解出小问题来解决整体问题: 动态规划从底部开始解决问题,将所有小问题解决,然后合并掉一个整体解决方案: function dynFib(n) { ...
- 使用 js 实现十大排序算法: 堆排序
使用 js 实现十大排序算法: 堆排序 堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法. 大顶堆:每个节点的值都大于或等于其子节点的值,在堆排序算法中用于升序排列: 小顶堆:每个 ...
- Java基础复习笔记基本排序算法
Java基础复习笔记基本排序算法 1. 排序 排序是一个历来都是很多算法家热衷的领域,到现在还有很多数学家兼计算机专家还在研究.而排序是计算机程序开发中常用的一种操作.为何需要排序呢.我们在所有的系统 ...
- 使用 js 实现十大排序算法: 快速排序
使用 js 实现十大排序算法: 快速排序 QuickSort 快速排序 /** * * @author xgqfrms * @license MIT * @copyright xgqfrms * @c ...
- 使用 js 实现十大排序算法: 桶排序
使用 js 实现十大排序算法: 桶排序 桶排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- 使用 js 实现十大排序算法: 计数排序
使用 js 实现十大排序算法: 计数排序 计数排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
随机推荐
- JAVA经典算法40题及解答
JAVA经典算法40题 [程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 1.程序分 ...
- C语言中%d,%o,%f,%e,%x的意义
printf(格式控制,输出列表) 格式控制包括格式说明和格式字符. 格式说明由“%”和格式字符组成,如%d%f等.它的作用是将输出的数据转换为指定的格式输出.格式说明总是由“%”字符开始的.不同类型 ...
- Linux shell判断文件和文件夹是否存在
shell判断文件,目录是否存在或者具有权限 #!/bin/sh myPath="/var/log/httpd/" myFile="/var /log/httpd/acc ...
- Bitwise AND of Numbers Range
Given a range [m, n] where 0 <= m <= n <= 2147483647, return the bitwise AND of all numbers ...
- win10远程桌面连接
有的情况下,Win10设置了允许远程桌面连接后,远程主机仍然不能桌面连接到目标主机上,这时可以在目标主机上尝试如下修改: 开始-->运行->gpedit.msc->计算机配置-> ...
- MongoDB副本集学习(二):基本测试与应用
简单副本集测试 这一节主要对上一节搭建的副本集做一些简单的测试. 我们首先进入primary节点(37017),并向test.test集合里插入10W条数据: . rs0:PRIMARY> ;i ...
- Java for LeetCode 173 Binary Search Tree Iterator
Implement an iterator over a binary search tree (BST). Your iterator will be initialized with the ro ...
- AJAX,JSON搜索智能提示
效果 开发结构参考AJAX,JSON用户校验 主要有两个核心文件 1,处理输入字符,进行后台搜索的servlet Suggest.java package org.guangsoft.servlet; ...
- July 15th, Week 29th Friday, 2016
A book is a gift that you can open again and again. 书是你可以一次又一次打开的礼物. Some gifts are born with you, a ...
- Linux C 单链表 读取文件 并排序 实例并解释
C的指针挺头疼的,先看一个例子: 给指针赋值和通过指针进行赋值这两种操作的差别确实让人费解.谨记区分的重要方法是:如果对左操作数进行解引用,则修改的是指针所指对象的值: 如果没有使用解引用操作, ...