JavaScript实现获取两个排序数组的中位数算法示例


Posted in Javascript onFebruary 26, 2019

本文实例讲述了JavaScript实现获取两个排序数组的中位数算法。分享给大家供大家参考,具体如下:

题目

给定两个大小为 m 和 n 的有序数组 nums1 和 nums2 。

请找出这两个有序数组的中位数。要求算法的时间复杂度为 O(log (m+n)) 。

你可以假设 nums1 和 nums2 不同时为空。

示例 1:

nums1 = [1, 3]
nums2 = [2]

中位数是 2.0

示例 2:

nums1 = [1, 2]
nums2 = [3, 4]

中位数是 (2 + 3)/2 = 2.5

分析:用数组排序方法轻松解决

JS代码:

var findMedianSortedArrays = function(nums1, nums2) {
  for(i=0;i<nums2.length;i++){
    nums1.push(nums2[i])
  }
  nums1=nums1.sort(function(a,b){ return b-a});//排序
  if(nums1.length%2==0){
    return (nums1[nums1.length/2]+nums1[nums1.length/2-1])/2 //中位数
  }
  else{return nums1[(nums1.length-1)/2]}
}
var nums1 = [1, 2]
var nums2 = [3, 4]
console.log(findMedianSortedArrays(nums1,nums2))

使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码,可得如下运行结果:

 JavaScript实现获取两个排序数组的中位数算法示例

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
ExtJS 2.0 实用简明教程之布局概述
Apr 29 Javascript
javascript 全角转换实现代码
Jul 17 Javascript
Node.js实战 建立简单的Web服务器
Mar 08 Javascript
JS获取当前日期和时间的简单实例
Nov 19 Javascript
元素未显示设置width/height时IE中使用currentStyle获取为auto
May 04 Javascript
js实现的tab标签切换效果代码分享
Aug 25 Javascript
Angular工具方法学习
Dec 26 Javascript
Bootstrap学习笔记之进度条、媒体对象实例详解
Mar 09 Javascript
js轮播图无缝滚动效果
Jun 17 Javascript
详解vue服务端渲染(SSR)初探
Jun 19 Javascript
解决ie11 SCRIPT5011:不能执行已释放Script的代码问题
May 05 Javascript
Moment.js实现多个同时倒计时
Aug 26 Javascript
小程序hover-class点击态效果实现
Feb 26 #Javascript
JS实现计算小于非负数n的素数的数量算法示例
Feb 26 #Javascript
vue使用Font Awesome的方法步骤
Feb 26 #Javascript
JS实现的杨辉三角【帕斯卡三角形】算法示例
Feb 26 #Javascript
create-react-app使用antd按需加载的样式无效问题的解决
Feb 26 #Javascript
JS实现电话号码的字母组合算法示例
Feb 26 #Javascript
JS实现的合并两个有序链表算法示例
Feb 25 #Javascript
You might like
PHP Stream_*系列函数
2010/08/01 PHP
Laravel中任务调度console使用方法小结
2017/05/07 PHP
Javascript MD4
2006/12/20 Javascript
根据对象的某一属性进行排序的js代码(如:name,age)
2010/08/10 Javascript
Pro JavaScript Techniques学习笔记
2010/12/28 Javascript
基于jquery的大众点评,分类导航实现代码
2011/08/23 Javascript
jquery DIV撑大让滚动条滚到最底部代码
2013/06/06 Javascript
AngularJS使用指令增强标准表单元素功能
2016/07/01 Javascript
JavaScript对象_动力节点Java学院整理
2017/06/23 Javascript
JavaScript实现删除数组重复元素的5种常用高效算法总结
2018/01/18 Javascript
浅谈Vue初学之props的驼峰命名
2018/07/19 Javascript
vue鼠标移入添加class样式,鼠标移出去除样式(active)实现方法
2018/08/22 Javascript
vue.js+element-ui动态配置菜单的实例
2018/09/07 Javascript
微信小程序授权登录及解密unionId出错的方法
2018/09/26 Javascript
QRCode.js二维码生成并能长按识别
2018/10/16 Javascript
es6数据变更同步到视图层的方法
2019/03/04 Javascript
layui添加动态菜单与选项卡
2019/07/26 Javascript
详解简单易懂的 ES6 Iterators 指南和示例
2019/09/24 Javascript
ant-design-vue 快速避坑指南(推荐)
2020/01/21 Javascript
[01:15:16]DOTA2-DPC中国联赛 正赛 Elephant vs Aster BO3 第一场 1月26日
2021/03/11 DOTA
从零学python系列之数据处理编程实例(二)
2014/05/22 Python
利用Python如何实现数据驱动的接口自动化测试
2018/05/11 Python
Pyorch之numpy与torch之间相互转换方式
2019/12/31 Python
Python super()方法原理详解
2020/03/31 Python
python文件读取失败怎么处理
2020/06/23 Python
python 中 .py文件 转 .pyd文件的操作
2021/03/04 Python
h5使用canvas画布实现手势解锁
2019/01/04 HTML / CSS
便利店的创业计划书
2014/01/15 职场文书
高中军训感想300字
2014/03/04 职场文书
党的群众路线教育实践活动自我剖析材料
2014/10/08 职场文书
四风批评与自我批评范文
2014/10/14 职场文书
失职检讨书大全
2015/01/26 职场文书
2015年收银工作总结范文
2015/04/01 职场文书
关于召开会议的通知
2015/04/15 职场文书
教你利用Selenium+python自动化来解决pip使用异常
2021/05/20 Python
Valheim服务器 Mod修改安装教程 【ValheimPlus】
2022/12/24 Servers