AI智能
改变未来

举例说明javascript冒泡排序


目录
  • 一、什么是冒泡排序
  • 二、举个例子
  • 第一轮:
  • 第二轮:
  • 第三轮:
  • 第四轮:
  • 第五轮:
  • 第六轮:
  • 总结
    • 一、什么是冒泡排序

      冒泡排序Bubble Sort,通过依次来比较相邻两个元素的大小,在每一次的比较的过程中,两个元素,通过交换来达到有序的目的。

      如果一组无序的数列想要从小到大排序,那么两个元素比较,通过交换来实现,左边的元素要比右边的元素要小。

      如果一组无序的数列想要从大到小排序,那么两个元素比较,通过交换来实现,左边的元素要比右边的元素要大。

      就像碳酸饮料中的气泡一样,从底部一直冒泡到顶部。

      二、举个例子

      假如有 2,4,7,5,3,6,1 这组数

      第一轮:

      i=0;

      j(内层循环)循环 6次,内层循环做的工作:相邻两个数比较,大的最终会放在后面,小的在前,一次循环外层循环控制次数,内层循环做判断

      j=0 1 2 3 4 5

      2 2 2 2 2 2 2
      4 4 4 4 4 4 4
      7 7 7 5 5 5 5
      5 5 5 7 3 3 3
      3 3 3 3 7 6 6
      6 6 6 6 6 7 1
      1 1 1 1 1 1 7
      arr[0] arr[1] arr[2]
      arr[1] arr[2] arr[3]

      第二轮:

      i=1;

      j(内层循环)循环 5次

      j=0 1 2 3 4 5

      2 2 2 2 2 2
      4 4 4 4 4 4
      5 5 5 3 3 3
      3 3 3 5 5 5
      6 6 6 6 6 1
      1 1 1 1 1 6
      7 7 7 7 7 7
      arr[0] arr[1] arr[2]
      arr[1] arr[2] arr[3]

      第三轮:

      i=2;

      j(内层循环)循环 4次

      2 2 2 2 2
      4 4 3 3 3
      3 3 4 4 4
      5 5 5 5 1
      1 1 1 1 5
      6 6 6 6 6
      7 7 7 7 7

      第四轮:

      i=3;

      j(内层循环)循环 3次

      2 2 2 2
      3 3 3 3
      4 4 4 1
      1 1 1 4
      5 5 5 5
      6 6 6 6
      7 7 7 7

      第五轮:

      i=4;

      2 2 2
      3 3 1
      1 1 3
      4 4 4
      5 5 5
      6 6 6
      7 7 7

      第六轮:

      i=5;

      2 1
      1 2
      3 3
      4 4
      5 5
      6 6
      7 7
      */

      <script type=\"text/javascript\" >// 示例1:function show(){var arr=[2,4,7,5,3,6,1];for(var i=0;i<arr.length-1;i++){for(var j=0;j<arr.length-1-i;j++){//1、比较相邻的两个数;大的在后,小的在前if(arr[j] > arr[j+1] ){var temp = arr[j];arr[j] = arr[j+1];arr[j+1] = temp;}}}console.log(arr);}// 示例2:<body><input type=\"text\" id=\"test\"><button type=\"button\" onclick=\"show()\">按我</button><input type=\"text\" id=\"sc\"></body>function show() {let oT=document.getElementById(\"test\").value;let sc=document.getElementById(\"sc\");// console.log(sc);// console.log(oT);let arr=oT.split(\"\");console.log(arr.length);for (var i = 0; i < arr.length - 1; i++) {for (var j = 0; j < arr.length - 1 - i; j++) {//1、比较相邻的两个数;大的在后,小的在前if (arr[j] > arr[j + 1]) {var temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}}// console.log(arr);sc.value=arr;}</script>

      总结

      本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

      您可能感兴趣的文章:

      • JS前端面试必备——基本排序算法原理与实现方法详解【插入/选择/归并/冒泡/快速排序】
      • JavaScript算法学习之冒泡排序和选择排序
      • JavaScript数据结构与算法之基本排序算法定义与效率比较【冒泡、选择、插入排序】
      • JavaScript实现的冒泡排序法及统计相邻数交换次数示例
      • 详解JS中的快速排序与冒泡
      • JavaScript实现经典排序算法之冒泡排序
      赞(0) 打赏
      未经允许不得转载:爱站程序员基地 » 举例说明javascript冒泡排序