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. 安装完毕后重启电脑即可运行
相关推荐
执风挽^2 小时前
Python基础编程题2
开发语言·python·算法·visual studio code
Z9fish2 小时前
sse哈工大C语言编程练习20
c语言·开发语言·算法
VT.馒头3 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
萧鼎3 小时前
Python 包管理的“超音速”革命:全面上手 uv 工具链
开发语言·python·uv
css趣多多3 小时前
一个UI内置组件el-scrollbar
前端·javascript·vue.js
-凌凌漆-3 小时前
【vue】pinia中的值使用 v-model绑定出现[object Object]
javascript·vue.js·ecmascript
Anastasiozzzz3 小时前
Java Lambda 揭秘:从匿名内部类到底层原理的深度解析
java·开发语言
刘琦沛在进步3 小时前
【C / C++】引用和函数重载的介绍
c语言·开发语言·c++
机器视觉的发动机4 小时前
AI算力中心的能耗挑战与未来破局之路
开发语言·人工智能·自动化·视觉检测·机器视觉
HyperAI超神经4 小时前
在线教程|DeepSeek-OCR 2公式/表格解析同步改善,以低视觉token成本实现近4%的性能跃迁
开发语言·人工智能·深度学习·神经网络·机器学习·ocr·创业创新