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

千锋教育学习笔记

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>
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 排序算法说明 (1)排序的定义:对一序列对象根据某个关键字进行排序; 输入:n个数:a1,a2,a3,…,an 输...
    code武阅读 693评论 0 0
  • Ba la la la ~ 读者朋友们,你们好啊,又到了冷锋时间,话不多说,发车! 1.冒泡排序(Bub...
    王饱饱阅读 1,830评论 0 7
  • 7种常用的排序算法总结 2016.04.30PoetryAlgorithm 排序算法:一种能将一串数据依照特定的排...
    raining_804f阅读 816评论 0 0
  • 今天上传某个jar包网络过慢,CTRL+C后,目录下出现了一堆乱七八糟的文件,如下图 于是,就想把这些文件删掉,想...
    简书_大洋阅读 320评论 0 0
  • 时常看不清自己。 那样一个人,仿佛不太像我。只不过她努力的样子,使心察觉到欣喜。 逝者如斯,不舍昼夜。今日月圆,湛...
    叶良呈阅读 260评论 0 1