加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

JavaScript冒泡排序与选择排序

发布时间:2019-10-30 18:43:53 所属栏目:建站 来源:kid编程
导读:算法与数据布局组成了措施,数据布局用于实现数据的暗示、存储、打点,算法通过行使数据完成必然的营业逻辑与操纵,最终实现了措施的成果。因此算法在编程中的重要性是不问可知的。许多伟大的算法都是借助最根基的算法实现的。本文首要选取经典排序算法中

算法与数据布局组成了措施,数据布局用于实现数据的暗示、存储、打点,算法通过行使数据完成必然的营业逻辑与操纵,最终实现了措施的成果。因此算法在编程中的重要性是不问可知的。许多伟大的算法都是借助最根基的算法实现的。本文首要选取经典排序算法中的冒泡排序与选择排序对JavaScript编程实现算法举办简朴描写与声名。

JavaScript冒泡排序与选择排序

算法声名

算法(Algorithm)是办理题目的一种计策机制,算法也是有限操纵指令的荟萃。凭证算法计策输入切合要求的数据,最终得到办理题目的输出功效。冒泡算法与选择算法首要用于实现对无序的数字荟萃举办排序。算法描写别离如下:

1、冒泡排序算法

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

算法进修-JavaScript冒泡排序与选择排序

冒泡排序算法表示图

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

2、选择排序算法

选择排序是指从未排序的序列中找到最小的值并取出放到已经排好次序的序列中,一向到未排序序列中的元素个数为零。即全部的元素都放到已经排好次序的序列中。该算法的要害在于从未排序的序列中找到最轻(数值最小)元素,放到已经排序好的序列中。选择排序算法表示如下图所示:

算法进修-JavaScript冒泡排序与选择排序

选择排序表示图

选择排序表示图如上图所示,选择的要害在于找到最小的值,并将其放到已经排序好的序列中。上图中未排序(待排序)荟萃为黄色部门,排序好的部门为绿色配景部门,每一举动一次排序,排序目标找到最小元素。通过上图可知选择出来的最小值依次为(1,5,9,12,17)。

冒泡排序实现

JavaScript冒泡排序首要借助JavaScript array数字工具实现待排序序列的存储,通过轮回语句遍历数组,从待排序序列的第一个元素开始与后头元素较量,如大于后头元素则互换,因此颠末一趟遍历,最大元素将会跑到array数组的末端。实当代码描写如下:

  1. var arr1=[9,1,4,13,7,8,20,23,15];  
  2. var wlen1=arr1.length; 
  3. var count1=0;//记录总执行次数  
  4. for(var i=0;i<arr1.length-1;i++) {  
  5. for(var j=0;j<wlen1;j++) {  
  6. if(arr1[j]>arr1[j+1]) {  
  7. var temp;  
  8. temp=arr1[j];  
  9. arr1[j]=arr1[j+1];  
  10. arr1[j+1]=temp;  
  11. count1++;  
  12. }  
  13. }  
  14. wlen1=wlen1-1;  

选择排序实现

凭证算法描写选择排序必要行使两个JavaScript数组工具,一个为待排序序列存储数据,一个为排序完成数组。别离从待排序序列数组中找到最小值并取出存储到完成排序数组中。arr数组为待排序数组,res数组为排序完成数组。行使javaScript实现选择排序代码描写如下:

  1. var arr=[9,1,4,13,7,8,20,23,15];  
  2.  var wlen=arr.length;  
  3.  var count=0;//记录已完成排序元素数目  
  4.  var res=[];//最终排序功效数组  
  5.  var minvalue=0; //思绪从未排序序列选择最小元素放到已经完成排序的数组中  
  6.  for(var i=0;i<wlen;i++) { //找到最小元素  
  7.  minvalue=arr[0];  
  8.  for(var j=0;j<arr.length;j++) {  
  9.  if(minvalue>arr[j]) {  
  10.  minvalue=arr[j];  
  11.  var temp;  
  12.  temp=arr[0];  
  13.  arr[0]=arr[j];  
  14.  arr[j]=temp;  
  15.  }  
  16.  count++;  
  17.  }  
  18.  arr.shift();  
  19.  res[i]=minvalue;  
  20.  } 

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

算法进修-JavaScript冒泡排序与选择排序

冒泡排序与选择测试功效

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读