网站首页 > 技术文章 正文
在面试时候,会经常考到排序算法,下面列举javascript常用的排序算法。
冒泡排序
通过相邻两个元素之间的比较和交换,使较大的元素逐渐从前面移向后面(升
序),就像水底下的气泡一样逐渐向上冒泡,所以被称为“冒泡”排序。冒泡排序的最坏时间复杂度为O(n2),平均时间复杂度为O(n2)。
代码演示:
var arr=[2,5,4,1,7,3,8,6,9,0]; function arrayMax(arr) { var temp = null; for (var i = 0;i<arr.length-1;i++){ for (var j = i+1;j<arr.length;j++){ //如果前面的数据比后面的大就交换 //两个数交换一定要声明一个变量,用来存储其中要被赋值的那个 if (arr[i]>arr[j]){ temp = arr[j]; arr[j] = arr[i]; arr[i] = temp; } } } return arr; } console.log(arrayMax(arr));
快速排序
元素的比较和交换是从两端向中间进行的,较大的元素一轮就能够交换到后面的位置,而较小的元素一轮就能交换到前面的位置,元素每次移动的距离较远,所以比较次数和移动次数较少,速度较快,故称为“快速排序”。
代码演示:
var times = 0; function queryArrayMax(arr) { //如果数组长度小于等于1无需判断直接返回即可 if (arr.length<=1){ return arr; } var arrIndex = Math.floor(arr.length/2);//获取中间值 这个是索引 var arrCenterVal = arr.splice(arrIndex,1);// 利用索引取出中间值 改变原始数组 var left= [],//存储小的 right = [];//存储大的 // 遍历数组 ,进行判断分配 for (var i = 0;i<arr.length;i++){ if (arr[i]<arrCenterVal){ left.push(arr[i])//比中间值小的放在左边数组 }else{ right.push(arr[i])//比中间值大的放在右边数组 } console.log("第"+(++times)+"次排序后:"+arr); } //递归执行以上操作,对左右两个数组进行操作,直到数组长度为<=1; return queryArrayMax(left).concat(arrCenterVal,queryArrayMax(right)) } console.log(queryArrayMax(arr));
欢迎大家转发和关注,后面将继续发布一些基础教程。
猜你喜欢
- 2025-06-10 前端流式输出(前端流式输出效果)
- 2025-06-10 前端基础进阶(一):内存空间详细图解
- 2025-06-10 JavaScript数组中slice、concat方法真的是深拷贝吗?
- 2025-06-10 Set代替Array去重,实测性能对比(set方法数组去重)
- 2025-06-10 JavaScript去除数组重复元素的几种方法
- 2025-06-10 Vue短文:如何使用v-for反转数组的顺序?
- 2025-06-10 判断变量是否为数组(如何判断某变量是否为数组数据类型)
- 2025-06-10 JavaScript数组剖析(js 数组处理方法)
- 2024-09-30 JavaScript数组_数组方法「二」(二十七)
- 2024-09-30 table组件,前端如何使用table组件打印数组数据
你 发表评论:
欢迎- 588℃几个Oracle空值处理函数 oracle处理null值的函数
- 580℃Oracle分析函数之Lag和Lead()使用
- 569℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 567℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 561℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 553℃【数据统计分析】详解Oracle分组函数之CUBE
- 539℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 535℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端懒加载 (49)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)