千家信息网

JavaScript怎么实现冒泡排序与选择排序

发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,本文小编为大家详细介绍"JavaScript怎么实现冒泡排序与选择排序",内容详细,步骤清晰,细节处理妥当,希望这篇"JavaScript怎么实现冒泡排序与选择排序"文章能帮助大家解决疑惑,下面跟着小
千家信息网最后更新 2025年12月01日JavaScript怎么实现冒泡排序与选择排序

本文小编为大家详细介绍"JavaScript怎么实现冒泡排序与选择排序",内容详细,步骤清晰,细节处理妥当,希望这篇"JavaScript怎么实现冒泡排序与选择排序"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

1、冒泡排序算法

冒泡算法顾名思义,可以将待排序序列中的每一个元素看成一个个气泡,假设气泡的大小用元素的数值表示,这样的话最大气泡(最大的元素数字)会最先升起来,这一过程即为冒泡。冒泡算法的关键在于将未排序部分最大元素依次后移动,在序列尾端从小到大形成排序好的有序序列。冒泡排序示意如下图所示:

冒泡排序算法示意图

冒泡排序算法示意图如上图所示,其中每一行表示一次排序,排序目的找到最大值,从待排序序列中取出最大值,放到红色小球区域中,红色小球区域表示已完成排序的序列。通过上图我们可以看出,每趟排序冒泡出来的元素分别为(17,12,9,5,1)。最终排好的序列为(1,5,9,12,17)。

2、选择排序算法

选择排序是指从未排序的序列中找到最小的值并取出放到已经排好顺序的序列中,一直到未排序序列中的元素个数为零。即所有的元素都放到已经排好顺序的序列中。该算法的关键在于从未排序的序列中找到最轻(数值最小)元素,放到已经排序好的序列中。选择排序算法示意如下图所示:

选择排序示意图

选择排序示意图如上图所示,选择的关键在于找到最小的值,并将其放到已经排序好的序列中。上图中未排序(待排序)集合为黄色部分,排序好的部分为绿色背景部分,每一行为一次排序,排序目的找到最小元素。通过上图可知选择出来的最小值依次为(1,5,9,12,17)。

冒泡排序实现

JavaScript冒泡排序主要借助JavaScript array数字对象实现待排序序列的存储,通过循环语句遍历数组,从待排序序列的第一个元素开始与后面元素比较,如大于后面元素则交换,因此经过一趟遍历,最大元素将会跑到array数组的末尾。实现代码描述如下:

var arr1=[9,1,4,13,7,8,20,23,15];  var wlen1=arr1.length; var count1=0;//记录总执行次数  for(var i=0;iarr1[j+1]) {  var temp;  temp=arr1[j];  arr1[j]=arr1[j+1];  arr1[j+1]=temp;  count1++;  }  }  wlen1=wlen1-1;  }

选择排序实现

按照算法描述选择排序需要使用两个JavaScript数组对象,一个为待排序序列存储数据,一个为排序完成数组。分别从待排序序列数组中找到最小值并取出存储到完成排序数组中。arr数组为待排序数组,res数组为排序完成数组。使用javaScript实现选择排序代码描述如下:

var arr=[9,1,4,13,7,8,20,23,15];   var wlen=arr.length;   var count=0;//记录已完成排序元素数量   var res=[];//最终排序结果数组   var minvalue=0; //思路从未排序序列选择最小元素放到已经完成排序的数组中   for(var i=0;iarr[j]) {   minvalue=arr[j];   var temp;   temp=arr[0];   arr[0]=arr[j];   arr[j]=temp;   }   count++;   }   arr.shift();   res[i]=minvalue;   }

JavaScript实现基本冒泡与选择排序算法描述如上所示,本例设计测试用例为(9,1,4,13,7,8,20,23,15),该待排序测试用例分别执行冒泡排序与选择排序,效果展示如下图

读到这里,这篇"JavaScript怎么实现冒泡排序与选择排序"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。

排序 序列 选择 元素 数组 算法 最小 最大 上图 示意图 从未 关键 文章 气泡 部分 存储 一行 代码 内容 区域 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 网吧服务器清零后不开机 公益网络技术网站 国家经济领域内网络安全问题 重庆网络安全工程师收费标准 服务器数据系统信息安全 软件开发残疾人 幻塔更换游戏服务器数据会同步吗 软件开发项目奖金管理制度 江苏旅游app小程序软件开发 霍山天气预报软件开发 内存分布式数据库 大鱼赌场这个游戏服务器 江淮官话语音数据库 服务器中的极限生存 福建企业云空间系统服务器云主机 甘肃信息化工业互联网软件开发 广东服务器风扇供应商云空间 信息网络安全需要编程么 数据库对数据的操作方式 考试计算机网络技术专业测试 数据库负载50% 华为推送服务器收不到微信消息 王者荣耀pc端服务器 关系数据库管理系统实现 广东什么是网络技术分类资费 服务器虚拟化安装oracle 辽宁时代网络技术询问报价 浪潮存储服务器定做 大鱼赌场这个游戏服务器 个人租用服务器的费用一年多少
0