排序算法 | JS
1、冒泡排序
function bubbleSort(arr,order){
let len = arr.length-1,flag=true
for(let i=0;(i<len)&&flag;i++){
flag=false
for(let j=0;j<len-i;j++){
if((arr[j]-arr[j+1])*order>0){
flag=true
let tran = arr[j]
arr[j]=arr[j+1]
arr[j+1]=tran
}
}
}
}
let arr=[2,3,0,5,1,6,8,4]
bubbleSort(arr,1)
console.log(arr)
2、插入排序
function insertSort(arr){
let len=arr.length-1
for(let i=1;i<len;i++){
let currrent=arr[i],j
for(j=i-1;j>=0&&arr[j]>currrent;j--){
arr[j+1]=arr[j]
}
arr[j+1]=currrent
}
}
let arr=[2,3,0,5,1,6,-6,4]
insertSort(arr)
console.log(arr)
3、快速排序
function quickSort(arr,low,high){
if(low>high) return
let mid=partition(arr,low,high)
quickSort(arr,low,mid-1)
quickSort(arr,mid+1,high)
}
function partition(arr,low,high){
for(i=low,j=low;j<high;j++){
if(arr[j]<arr[high]){
swap(arr,i++,j)
}
}
swap(arr,i,j)
return i
}
function swap(arr,i,j){
let tran=arr[i]
arr[i]=arr[j]
arr[j]=tran
}
let arr=[2,3,0,5,1,6,8,4]
quickSort(arr,0,arr.length-1)
console.log(arr)
4、归并排序
function mergeSort(arr,low,high){
if(low>=high) return
let mid = Math.floor((low+high)/2)
mergeSort(arr,low,mid)
mergeSort(arr,mid+1,high)
merge(arr,low,mid,high)
}
function merge(arr,low,mid,high){
let k=low,i=low,j=mid+1
let copy=[...arr]
while(k<=high){
if(i>mid){
arr[k++]=copy[j++]
}else if(j>high){
arr[k++]=copy[i++]
}else if(copy[i]>copy[j]){
arr[k++]=copy[j++]
}else {
arr[k++]=copy[i++]
}
}
}
let arr=[2,3,0,5,1,6,8,4]
mergeSort(arr,0,arr.length-1)
console.log(arr)
5、堆排序
function heapify(arr,i,high){
if(i>=high) return
let left=2*i+1
let right =2*i+2
let max=i
if((left<high)&&(arr[max]<arr[left])) max =left
if((right<high)&&(arr[max]<arr[right])) max =right
if(i!=max){
swap(arr,i,max)
heapify(arr,max,high)
}
}
function buildHeap(arr){
let high = arr.length
for(let m=Math.floor(high/2);m>=0;m--){
heapify(arr,m,high)
}
}
function heapSort(arr){
buildHeap(arr)
let high=arr.length
let j=high-1
for(let i=0;i<high;i++){
swap(arr,0,j)
heapify(arr,0,j--)
}
}
function swap(arr,i,j){
let tran = arr[i]
arr[i]= arr[j]
arr[j]= tran
}
arr=[2,-1,7,6,5,12]
heapSort(arr)
console.log(arr)
6、原生排序
function sort(arr,order){
arr.sort((a,b)=>{
return (a-b)*order
})
}
let arr=[2,3,0,5,1,6,8,4]
sort(arr,-1)
console.log(arr)

不同条件下,排序方法的选择
(1)若n较小(如n≤50),可采用直接插入或直接选择排序。
当记录规模较小时,直接插入排序较好;否则因为直接选择移动的记录数少于直接插人,应选直接选择排序为宜。
(2)若文件初始状态基本有序(指正序),则应选用直接插人、冒泡或随机的快速排序为宜;
(3)若n较大,则应采用时间复杂度为O(nlgn)的排序方法:快速排序、堆排序或归并排序。
快速排序是目前基于比较的内部排序中被认为是最好的方法,当待排序的关键字是随机分布时,快速排序的平均时间最短;
堆排序所需的辅助空间少于快速排序,并且不会出现快速排序可能出现的最坏情况。这两种排序都是不稳定的。
若要求排序稳定,则可选用归并排序。但本章介绍的从单个记录起进行两两归并的 排序算法并不值得提倡,通常可以将它和直接插入排序结合在一起使用。先利用直接插入排序求得较长的有序子文件, 然后再两两归并之。因为直接插入排序是稳定 的,所以改进后的归并排序仍是稳定的。
参考:
《算法设计指南》,Skiena
https://kaiwu.lagou.com/course/courseInfo.htm?courseId=3#/detail/pc?id=31
堆排序:https://www.bilibili.com/video/BV1Eb41147dK?from=search&seid=5680730895913351029
排序算法 | JS的更多相关文章
- 八大排序算法JS及PHP代码实现
从学习数据结构开始就接触各种算法基础,但是自从应付完考试之后就再也没有练习过,当在开发的时候也是什么时候使用什么时候去查一下,现在在学习JavaScript,趁这个时间再把各种基础算法整理一遍,分别以 ...
- 分析并封装排序算法(js,java)
前言 本次来分享一下排序的api底层的逻辑,这次用js模拟,java的逻辑也是差不多. 先看封装好的api例子: js的sort排序 java的compareTo排序 自己模拟的代码(JS) func ...
- 十大经典排序算法-JS篇
http://web.jobbole.com/87968/ 虽然是JS篇,但其他编程语言(例如java)实现起来是差不多的.
- JavaScript版几种常见排序算法
今天发现一篇文章讲“JavaScript版几种常见排序算法”,看着不错,推荐一下原文:http://www.w3cfuns.com/blog-5456021-5404137.html 算法描述: * ...
- http://www.html5tricks.com/demo/jiaoben2255/index.html 排序算法jquery演示源代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.or ...
- 八大排序算法总结与java实现(转)
八大排序算法总结与Java实现 原文链接: 八大排序算法总结与java实现 - iTimeTraveler 概述 直接插入排序 希尔排序 简单选择排序 堆排序 冒泡排序 快速排序 归并排序 基数排序 ...
- JS写的排序算法演示
看到网上有老外写的,就拿起自已之前完成的jmgraph画图组件也写了一个.想了解jmgraph的请移步:https://github.com/jiamao/jmgraph 当前演示请查看:http:/ ...
- 排序图解:js排序算法实现
之前写过js实现数组去重, 今天继续研究数组: 排序算法实现. 排序是数据结构主要内容,并不限于语言主要在于思想:大学曾经用C语言研究过一段时间的排序实现, 这段时间有空用JS再将排序知识点熟悉一遍. ...
- 常见排序算法基于JS的实现
一:冒泡排序 1. 原理 a. 从头开始比较相邻的两个待排序元素,如果前面元素大于后面元素,就将二个元素位置互换 b. 这样对序列的第0个元素到n-1个元素进行一次遍历后,最大的一个元素就“沉”到序列 ...
- JS家的排序算法
由于浏览器的原生支持(无需安装任何插件),用JS来学习数据结构和算法也许比c更加便捷些.因为只需一个浏览器就能啪啪啪的调试了.比如下图我学习归并排序算法时,只看代码感觉怎么都理解不了,但是结合chro ...
随机推荐
- 四种语言刷算法之47. 全排列 II
47. 全排列 II 1.C /** * Return an array of arrays of size *returnSize. * The sizes of the arrays are re ...
- Vulnhub:recon靶机
kali:192.168.111.111 靶机:192.168.111.188 信息收集 端口扫描 nmap -A -v -sV -T5 -p- --script=http-enum 192.168. ...
- K8s集群调度
k8s 调度器 Scheduler 是 kubernetes 的调度器,主要的任务是把定义的 pod 分配到集群的节点上.听起来非常简单,但有很多要考虑的问题: 公平:如何保证每个节点都能被分配资源 ...
- 周练3(php反序列化)
serialize()函数 $s = serialize($变量); //该函数将变量数据进行序列化转换为字符串 file_put_contents('./目标文本文件', $s); //将$s保存到 ...
- es 6中for in与for of适用对象
在 ES6 中提供了 for-of,可以很方便的遍历数组和类数组,但是却不能遍历对象,这是为什么,与 for-in 仅仅相差一个单词,用途也是遍历,为什么却不能使用在对象上? 查资料后得知,原来 ES ...
- Codeforces 919E Congruence Equation(循环节+数论)
Link 题意 给$n, m, p, x$,求有多少个$n(1\leq n \leq x)$使得$n·a^{n}=b(\textrm{mod}\;p)$成立 思路 考虑一下左边的循环节长度,由于$n% ...
- DotNetCore2.1使用GitLab通过阿里云自动构建镜像上传阿里云仓库在Docker运行
操作步骤: 1.安装GitLab并添加项目(此处省略安装过程) 2.获取GitLab的Access Tokens 3.创建空的DotNetCore2.1 Api项目 4.项目添加Docker支持,文件 ...
- 每次 git 都需要输入用户名和密码的解决办法
git config --global credential.helper store git pull /git push (第一次输入,下次就不用再次输入数据)
- cross-env 运行跨平台设置和使用环境变量的脚本
1.1 cross-env是什么 运行跨平台设置和使用环境变量的脚本 1.2 出现原因 当您使用 NODE_ENV=production, 来设置环境变量时,大多数 Windows 命令提示将会阻塞( ...
- io流转换为Multipart文件
io流转换为Multipart文件 个人的话是运用到了minio文件服务器保存文件,前端(vue)异步上传文件后,由于要提升用户体验效果,先上传文件到后台服务器,返回视频在文件服务器的link()参数 ...