JavaScript实现获取两个排序数组的中位数算法示例
2019-03-28 10:58
489 查看
本文实例讲述了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程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- 【LeetCode-面试算法经典-Java实现】【004-Median of Two Sorted Arrays(两个排序数组的中位数)】
- JavaScript中数组的合并以及排序实现示例
- 【算法】【分治】两个排序数组的中位数
- 分享两个JavaScript打乱数组顺序实现随机排序洗牌的方法(应用于音乐视频的随机播放等)
- javascript 常见数组操作( 1、数组整体元素修改 2、 数组筛选 3、jquery 元素转数组 4、获取两个数组中相同部分或者不同部分 5、数组去重并倒序排序 6、数组排序 7、数组截取slice 8、数组插入、删除splice(需明确位置) 9、数组遍历 10、jQuery根据元素值删除数组元素的方)
- JavaScript实现数组全排列、去重及求最大值算法示例
- JavaScript中数组的合并以及排序实现示例
- 算法:两个排序数组的中位数
- Javascript 数组自定义排序,并获取排序后的保存原索引的同序数组(堆排序实现)
- JavaScript基于对象方法实现数组去重及排序操作示例
- 获取数组排序后的index算法实现
- php不用内置函数对数组排序的两个算法代码
- JavaScript中实现数组的排序、乱序和搜索
- Java实现O(log(n+m))两个有序数组中第K大元素或中位数
- javascript的数组元素,为Array增加两个函数,实现删除功能
- Median of Two Sorted Arrays(找两个排序数组的中位数,二分法)
- 数组几种常见排序的javascript实现
- 【LeetCode-面试算法经典-Java实现】【026-Remove Duplicates from Sorted Array(删除排序数组中的重复元素)】
- C#中定义数组和一个简单排序算法实现。
- 求两个等长有序数组的中位数的logN算法 分治法