首页 > 开发 > JS > 正文

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

2024-05-06 16:48:29
字体:
来源:转载
供稿:网友

本文实例讲述了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))

可得如下运行结果:

 JavaScript,排序数组,中位数,算法

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


注:相关教程知识阅读请移步到JavaScript/Ajax教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表