快速排序

采用二分法,取出中间数,数组每次和中间数比较,小的放到左边,大的放到右边

<script>

var arr = [3, 1, 4, 6, 5, 7, 2]; 

        function quickSort(arr) {

            if (arr.length == 0) {

                return [];    // 返回空数组

            }

            // 获取中间数

            var cIndex = Math.floor(arr.length / 2);

            // console.log(arr.length / 2);

            var c = arr.splice(cIndex, 1);

            var l = [];

            var r = []; 

            for (var i = 0; i < arr.length; i++) {

                if (arr[i] < c) {

                    // 中间数的左侧

                    l.push(arr[i]);

                } else {

                    // 中间数的右侧

                    r.push(arr[i]);

                }

            }

            // 这个递归

            return quickSort(l).concat(c, quickSort(r));

        }

        // 调用函数

        let res = quickSort(arr);

        console.log(res);

//结果为[1,2,3,4,5,6,7]

</script>


从中间数为2往上一层走就是[2]+3就是[2,3]一直往上走就是[1,2,3,4,5,6,7]

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