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

 更新时间:2019年02月26日 11:23:46   作者:qqlaowang  
这篇文章主要介绍了JavaScript实现获取两个排序数组的中位数算法,涉及javascript数组遍历及数值计算相关操作技巧,需要的朋友可以参考下

本文实例讲述了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.jb51.net/code/HtmlJsRun测试上述代码,可得如下运行结果:

 

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结

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

相关文章

  • 微信小程序后端实现授权登录

    微信小程序后端实现授权登录

    这篇文章主要介绍了微信小程序后端实现授权登录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • 利用js实现选项卡的特别效果的实例

    利用js实现选项卡的特别效果的实例

    利用js实现选项卡的特别效果的实例,需要的朋友可以参考一下
    2013-03-03
  • 支持ie与FireFox的剪切板操作代码

    支持ie与FireFox的剪切板操作代码

    支持ie与FireFox的剪切板代码,包括读取与写入剪切板的实现代码。
    2009-09-09
  • 微信小程序3种位置API的使用方法详解

    微信小程序3种位置API的使用方法详解

    这篇文章主要介绍了微信小程序3种位置API的使用方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • js实现div模拟模态对话框展现URL内容

    js实现div模拟模态对话框展现URL内容

    这篇文章主要介绍了js实现div模拟模态对话框展现URL内容的功能,涉及javascript动态操作页面元素样式与ajax调用的相关技巧,需要的朋友可以参考下
    2016-05-05
  • ionic3双击返回退出应用的方法

    ionic3双击返回退出应用的方法

    这篇文章主要为大家详细介绍了ionic3双击返回退出应用的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • JS与Jquery获取屏幕、浏览器、页面的宽度和高度对比整理

    JS与Jquery获取屏幕、浏览器、页面的宽度和高度对比整理

    页面的展示,从外到内的容器为:屏幕、浏览器以及页面本身。HTML元素展现在页面内,页面展现在浏览器内,而浏览器展现在屏幕内。通过Js的一些对象可以获取这些容器的高度、宽度。容器的尺寸是指当前分辨率下的高度和宽度(分辨率不同,值就不相同)。
    2023-02-02
  • javascript CSS画图之基础篇

    javascript CSS画图之基础篇

    要在浏览器上动态地画图(矢量图),个人觉得矢量图中最关键的两点.
    2009-07-07
  • javascript常用经典算法实例详解

    javascript常用经典算法实例详解

    这篇文章主要介绍了javascript常用算法,结合实例形式较为详细的分析总结了JavaScript中常见的各种排序算法以及堆、栈、链表等数据结构的相关实现与使用技巧,需要的朋友可以参考下
    2015-11-11
  • 一些技巧性实用js代码小结

    一些技巧性实用js代码小结

    实现页面最大化 默认img图片 屏蔽鼠标右键 取消选取防止复制等实现代码。
    2009-10-10

最新评论