举例说明javascript冒泡排序

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

    一、什么是冒泡排序

    冒泡排序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>
    

    总结

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

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 JavaScript 举例说明javascript冒泡排序 https://www.niceym.com/19991.html