JavaScript实现归并排序及vscode输出乱码解决

思路

归并排序思路:11.6 归并排序 - Hello 算法

总体上来讲就是 递归分解 + 归并排序 代码如下↓

代码

javascript 复制代码
//归并排序
function merge(left, right){
    console.log(flag++);
    console.log(left);
    console.log(right);
    let result = new Array();
    let il = 0, ir = 0;
    //左右两个数组的元素依次进行比较 将较小的元素加入结果数组中 
    while(il < left.length && ir < right.length){
        if(left[il] < right[ir]){
            result.push(left[il]);
            il++;
        }else{
            result.push(right[ir]);
            ir++;
        }
    }
    //左边数组、右边数组还有剩余时,将剩余元素加入结果数组
    while(il < left.length){
        result.push(left[il]);
        il++;
    }
    while(ir < right.length){
        result.push(right[ir]);
        ir++;
    }
    return result;
}
//递归分解
function mergeSort(array){
    let length = array.length;
    //array长度为1 不需要排序 直接返回
    if(length <= 1){
        return array;
    }
    //找到中间索引值
    const mid = parseInt(length / 2);
    //截取左半部分和右半部分
    const left = array.slice(0,mid);
    const right = array.slice(mid);
    //递归分解后 选择排序合并
    return merge(mergeSort(left),mergeSort(right));
}

输入:

javascript 复制代码
var nums = [7,3,2,6,0,1,5,4];

输出:

javascript 复制代码
const result = mergeSort(nums);
console.log(result);

输出结果:

javascript 复制代码
[0, 1, 2, 3, 4, 5, 6, 7]

资料补充

如何在vscode中使用运行js(输出结果出现乱码) ?

  1. 在vscode中安装Code Runner插件
  2. node.js官网下载安装node.js
  3. 安装完毕后重启电脑即可运行
相关推荐
如竟没有火炬10 分钟前
全排列——交换的思想
开发语言·数据结构·python·算法·leetcode·深度优先
WeilinerL15 分钟前
泛前端代码覆盖率探索之路
前端·javascript·测试
嵌入式小李.man22 分钟前
C++第十三篇:继承
开发语言·c++
Bryce李小白29 分钟前
Kotlin Flow 的使用
android·开发语言·kotlin
JNU freshman1 小时前
vue 之 import 的语法
前端·javascript·vue.js
剑亦未配妥1 小时前
Vue 2 响应式系统常见问题与解决方案(包含_demo以下划线开头命名的变量导致响应式丢失问题)
前端·javascript·vue.js
爱吃的强哥1 小时前
Vue2 封装二维码弹窗组件
javascript·vue.js
凉柚ˇ1 小时前
Vue图片压缩方案
前端·javascript·vue.js
jarreyer1 小时前
python离线包安装方法总结
开发语言·python
李辰洋1 小时前
go tools安装
开发语言·后端·golang