当前位置: 首页 > news >正文

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

思路

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

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

代码

//归并排序
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));
}
输入:
var nums = [7,3,2,6,0,1,5,4];

输出:

const result = mergeSort(nums);
console.log(result);

输出结果:

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

资料补充

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

  1. 在vscode中安装Code Runner插件
  2. 去node.js官网下载安装node.js
  3. 安装完毕后重启电脑即可运行
http://www.lryc.cn/news/294216.html

相关文章:

  • Redis面试题40
  • 2024年危险化学品经营单位安全管理人员证考试题库及危险化学品经营单位安全管理人员试题解析
  • Kafka相关内容复习
  • JVM之Java内存区域
  • 几个MySQL系统调优工具
  • Linux内核与驱动面试经典“小”问题集锦(2)
  • windws安装mysql详细步骤
  • Linux的库文件
  • JAVA Web 学习(五)Nginx、RPC、JWT
  • Python编程的十大神奇依赖库
  • Java类的继承
  • 【DC渗透系列】DC-4靶场
  • 开源软件全景解析:驱动技术创新与行业革新的力量
  • 目标检测及相关算法介绍
  • 跟着cherno手搓游戏引擎【20】混合(blend)
  • leetcode 3.无重复字符的最长字串(滑动窗口) (C++)DAY2
  • Android Build 依赖项
  • SpringMVC精简知识点
  • 如何写好论文——(17)如何用批判性思维检阅文献
  • git将项目的某次签入遴选(Cherry-Pick)另一个项目
  • 开源节点框架STNodeEditor使用
  • 算法每日一题: Nim游戏 | 找规律
  • 分类预测 | Matlab实现GAF-PCNN-MATT格拉姆角场和双通道PCNN融合多头注意力机制的分类预测/故障识别
  • Dockerfile保留字
  • Linux的7个运行级别
  • Linux期末总复习( 详解 )
  • 【Linux系统化学习】进程等待
  • 前端学习笔记 | HTML5+CSS3静态网页制作的技巧(持续更新)
  • docker安装-centos
  • Redis入门指南