美文网首页
常用排序算法(系统排序、冒泡排序、选择排序)编程实现(HTML5

常用排序算法(系统排序、冒泡排序、选择排序)编程实现(HTML5

作者: 花爬满篱笆 | 来源:发表于2020-04-24 08:18 被阅读0次

千锋教育学习笔记

1、系统排序

1)reverse() 逆向排序 原数组顺序倒过来

【格式】 数组.reverse();

<script type="text/javascript">
                    var arr = [10,50,30,40];
                    arr.reverse();
                    alert(arr);//40,30,50,10
</script>

2) sort() 将数组中的元素升序排序

【格式】数组.sort();

<script type="text/javascript">
                    var arr = [10,50,27,40];
                    arr.sort();
                    alert(arr);//10,27,40,50
</script>

【注意】sort默认是按照字符串进行排序,所以面对像13和5这样的,会默认从第一位开始比较,1比5小,则判断13比5小。这样会导致出现错误。
如下:

<script type="text/javascript">
                    var arr = [10,1,5,15];
                    arr.sort();
                    alert(arr);//1,10,15,5
</script>

所以,一般情况下,我们需要自己去编写排序算法,系统提供给我们的排序函数,用的比较少。

2、冒泡排序

【原理】前后两个数两两进行比较,如果符合交换条件就交换位置,直到所有数据排序完成,结束比较。
【注】这里想要让数组从小到大进行排列,从大到小思想相同,代码将 前后两个数比较的比较符if(arr[j] > arr[j+1])换成小于号即可,( if(arr[j] < arr[j+1]))。
//var arr = [9,8,7,6,5,4];
第一轮
9,8,7,6,5,4
8,9,7,6,5,4
8,7,9,6,5,4
8,7,6,9,5,4
8,7,6,5,9,4
8,7,6,5,4,9
每一轮取出了一个最大的数,放在正确的位置。
第二轮
7,8,6,5,4
7,6,8,5,4
7,6,5,8,4
7,6,5,4,8
第三轮
7,6,5,4
6,7,5,4
6,5,7,4
6,5,4,7
第四轮
6,5,4
5,6,4
5,4,6
第五轮
5,4
4,5

<!DOCTYPE html>
<html>
      <head>
            <meta charset="utf-8" />
            <title>冒泡排序</title>
      </head>
      <script type="text/javascript">
            var arr = [9,8,7,6,5,4];
               for(var i = 0;i < arr.length;i++){
                     //每一轮比较的次数是总的元素减去当前的轮数
                     for(var j = 0; j <arr.length-i-1;j++){
                          //判断前后两个数是否符合交换条件
                          if(arr[j] > arr[j+1]){
                               var tmp = arr[j];
                               arr[j] = arr[j+1];
                               arr[j+1] = tmp;
                          }
                     }
               }
               alert(arr);
      </script>
      <body>            
      </body>
</html>

3、选择排序

【原理】通过比较首先选出最小的数放在第一个位置上,然后在其余的数中选择次小数放在第二个位置,以此类推,直到所有数据成为有序序列。
【又名】打擂台法
【注】这里想要让数组从小到大进行排列,从大到小思想相同,代码将 前后两个数比较的比较符if(arr[i] > arr[j])换成小于号即可,( if(arr[i] < arr[j]))。

<!DOCTYPE html>
<html>
      <head>
            <meta charset="utf-8" />
            <title>选择排序</title>
      </head>
      <script type="text/javascript">
            var arr = [9,8,7,6,5,4];
               for(var i = 0;i < arr.length-1;i++){                   
                     for(var j = i+1; j <arr.length;j++){
                          if(arr[i] > arr[j]){
                               var tmp = arr[i];
                               arr[i] = arr[j];
                               arr[j] = tmp;
                          }
                     }
               }        
               alert(arr);
      </script>
      <body>            
      </body>
</html>

相关文章

  • python 排序算法

    文章概述 介绍各大常用经典的排序算法和效率,以及python实现常用算法(冒泡排序,选择排序,快速排序,插入排序)...

  • Java语言——数组排序算法

    数组有很多常用的算法,包括冒泡排序、直接选择排序和反转排序。 一、冒泡排序 冒泡排序是最常用的数组排序算法之一,它...

  • 常用的排序算法

    常用的排序算法 常用的排序算法插入排序折半插入排序shell 排序冒泡排序选择排序快速排序基数排序归并排序堆排序K...

  • 排序算法

    概述 常用排序算法 冒泡排序 插入排序 选择排序 归并排序 快速排序 冒泡排序 步骤 比较相邻元素,如果前面元素比...

  • Java实现各种常用的排序算法

    Java实现各种常用的排序算法,包括:冒泡排序、插入排序、二分排序、选择排序、希尔排序、堆排序、快速排序(两种写法...

  • 排序算法的实现

    用java对常用内部排序算法的实现。 对冒泡排序,简单选择排序,直接插入排序,希尔排序,归并排序的简单实现(缺少快...

  • 七大排序算法之冒泡排序

    七大排序算法之冒泡排序 @(算法笔记)[排序算法, 冒泡排序, C++实现] 冒泡排序介绍 冒泡排序是七大排序算法...

  • java 实现排序算法之「选择排序」

    java 实现排序算法系列 继冒泡排序算法之后,选择排序终于和大家见面了。为什么冒泡排序之后要说选择排序呢,是因为...

  • 算法-冒泡排序

    算 法:冒泡排序算法时间复杂度: 冒泡排序算法概述 冒泡排序伪代码 冒泡排序实现 冒泡排序算法概述 冒泡排...

  • 图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序

    图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序 图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序

网友评论

      本文标题:常用排序算法(系统排序、冒泡排序、选择排序)编程实现(HTML5

      本文链接:https://www.haomeiwen.com/subject/ncfxwhtx.html