LeetCode#5 两个排序数组的中位数
中位数是 2.0
中位数是 (2 + 3)/2 = 2.5
import java.io.IOException;
import java.util.Arrays;
import java.util.Scanner; public class MedianSortedArrays {
public static void main(String[] args) throws IOException{
/*获取输入内容*/
Scanner input = new Scanner(System.in);
System.out.println("请输入第一个数组,元素间以逗号隔开:");
int[] nums1=stringToArray(input.nextLine());
System.out.println("请输入第二个数组,元素间以逗号隔开:");
int[] nums2=stringToArray(input.nextLine());
System.out.println("这两个数组的中位数是:");
Solution getMedian=new Solution();
Arrays.sort(nums1);
Arrays.sort(nums2);
double median=getMedian.findMedianSortedArrays(nums1,nums2);
System.out.println(median);
} /**
* 将获取的字符串转为数组
*/
public static int[] stringToArray(String str){
String[] strArr= str.split(",");
int[] arr=new int[strArr.length];
for(int i=0;i<strArr.length;i++){
arr[i]=Integer.parseInt(strArr[i].trim());
}
return arr;
}
} class Solution {
public double findMedianSortedArrays(int[] nums1, int[] nums2) {
double midian;
int[] index=getIndex(nums1.length+nums2.length);
midian=getMedian(nums1,nums2,index);
return midian;
} /**
* 获取中位数在组合后的数组中应当存在的位数
* @param arrLength
* @return
*/
public int[] getIndex(int arrLength){
int[] index =new int[2];
index[0]=(arrLength-1)/2;//(数组长度-1)/2为中位数在有序数组中的下标之一
if(arrLength%2==0){ //当数组长度为偶数,则中位数是(数组长度-1)/2和(数组长度-1)/2+1这两个下标对应元素的平均值
index[1]=index[0]+1;
}
return index;
} /**
* 获取中位数
* @param nums1
* @param nums2
* @param index 中位数下标对应数组[(数组长度-1)/2,(数组长度-1)/2+1]或[(数组长度-1)/2,0]
* @return
*/
public double getMedian(int[] nums1, int[] nums2,int[] index){
double sum=0; //记录中位数对应下标两个元素之和
int maxIndex; //记录中位数下标数组的较大数
double indexLength; /*此处获取中位数最大下标作为循环标记*/
if(index[1]==0){
maxIndex=index[0];
indexLength=1;
}else{
maxIndex=index[1];
indexLength=2;
} /*获取两个数组中的对应下标元素之和*/
int j=0,k=0,thisIndex=0,thisNum = 0;
while(thisIndex<=maxIndex){
if(j<nums1.length&&k<nums2.length){ //当两个数组均可遍历时
if(nums1[j]>=nums2[k]){ //比较元素大小,当某一数组元素小,便推向该数组下一个元素
thisNum=nums2[k]; //记录比较所得的较小元素,作为thisNum
k++;
}else{
thisNum=nums1[j];
j++;
}
}else{ //当有数组遍历结束,但仍未找到中位数时
if(j==nums1.length){ //遍历完的数组不再参与thisNum的记录,只进行另外一个数组的遍历
thisNum=nums2[k];
k++;
}
if(k==nums2.length){
thisNum=nums1[j];
j++;
}
} if(thisIndex==maxIndex){ //若遍历的次数达到中位数下标要求,便做和,记录中位数相关元素之和
sum+=thisNum;
}
if(index[1]!=0&&thisIndex==maxIndex-1){
sum+=thisNum;
} thisIndex++; //遍历标记
}
return sum/indexLength; //返回中位数
}
}
class Solution {
public double findMedianSortedArrays(int[] nums1, int[] nums2) {
int m = nums1.length, n = nums2.length, left = (m + n + 1) / 2, right = (m + n + 2) / 2;
return (findKth(nums1, nums2, left) + findKth(nums1, nums2, right)) / 2.0;
}
int findKth(int[] nums1, int[] nums2, int k) {
int m = nums1.length, n = nums2.length;
if (m > n) return findKth(nums2, nums1, k);
if (m == 0) return nums2[k - 1];
if (k == 1) return Math.min(nums1[0], nums2[0]);
int i = Math.min(m, k / 2), j = Math.min(n, k / 2);
if (nums1[i - 1] > nums2[j - 1]) {
return findKth(nums1, Arrays.copyOfRange(nums2, j, n), k - j);
} else {
return findKth(Arrays.copyOfRange(nums1, i, m), nums2, k - i);
}
}
}
LeetCode#5 两个排序数组的中位数的更多相关文章
- LeetCode 4 - 两个排序数组的中位数 - [分治]
题目链接:https://leetcode-cn.com/problems/median-of-two-sorted-arrays/description/ 给定两个大小为 m 和 n 的有序数组 n ...
- leetcode 4.两个排序数组的中位数
题目: 给定两个大小为 m 和 n 的有序数组 nums1 和 nums2 . 请找出这两个有序数组的中位数.要求算法的时间复杂度为 O(log (m+n)) . 你可以假设 nums1 和 nums ...
- leetcode,两个排序数组的中位数
先上题目描述: 给定两个大小为 m 和 n 的有序数组 nums1 和 nums2 . 请找出这两个有序数组的中位数.要求算法的时间复杂度为 O(log (m+n)) . 你可以假设 nums1 和 ...
- leetcode python两个排序数组的中位数
给定两个大小为 m 和 n 的有序数组 nums1 和 nums2 . 请找出这两个有序数组的中位数.要求算法的时间复杂度为 O(log (m+n)) . 你可以假设 nums1 和 nums2 不同 ...
- LeetCode(4):两个排序数组的中位数
Hard! 题目描述: 有两个大小为 m 和 n 的排序数组 nums1 和 nums2 . 请找出两个排序数组的中位数并且总的运行时间复杂度为 O(log (m+n)) . 示例 1: nums1 ...
- LeetCode4. 两个排序数组的中位数
4. 两个排序数组的中位数 问题描述 There are two sorted arrays nums1 and nums2 of size m and n respectively.Find the ...
- 2.Median of Two Sorted Arrays (两个排序数组的中位数)
要求:Median of Two Sorted Arrays (求两个排序数组的中位数) 分析:1. 两个数组含有的数字总数为偶数或奇数两种情况.2. 有数组可能为空. 解决方法: 1.排序法 时间复 ...
- LeetCode-4. 两个排序数组的中位数(详解)
链接:https://leetcode-cn.com/problems/median-of-two-sorted-arrays/description/ 有两个大小为 m 和 n 的排序数组 nums ...
- JavaScript实现获取两个排序数组的中位数算法示例
本文实例讲述了JavaScript排序代码实现获取两个排序数组的中位数算法.分享给大家供大家参考,具体如下: 题目 给定两个大小为 m 和 n 的有序数组 nums1 和 nums2 . 请找出这两个 ...
随机推荐
- maven相关说明,以及使用Testng相关
配置Apache Maven Apache Maven使用本身的配置和建立的项目位于许多地方: MAVEN_OPTS环境变量: 该变量包含用于启动运行Maven的JVM的参数,可用于向Maven提供其 ...
- js的语法糖?
++“”里面的+“”默认被变成“0”了 前端多写了个+号导致的bug,网址后面多一个0.虽然不知道是什么原因,但是感觉是js的隐式替换
- WCF 内置绑定在不同的传输安全模式下的信道层
basicHttpBinding Transport安全模式信道层 Message安全模式信道层 TransportWithMessageCredential安全模式信道层 TransportCred ...
- [JQuery] Using skill in JQuery
Using skill of JQuery 获取兄弟节点 $('#id').siblings() 当前元素的所有兄弟节点 $('#id').prev() 当前元素的前一个兄弟节点 $('#id').p ...
- jquery--实现类似淘宝星星评分功能
- 不正之处,欢迎指正.^-^.好绕的话 贴码.html <body> <div id="div"> <ul> <li>☆< ...
- JavaSE_4_集合
1.Map和ConcurrentHashMap的区别? Map和ConcurrentHashMap的区别,Map是接口,ConcurrentHashMap是实现类 2.hashMap内部具体如何实现的 ...
- C#工程缺少IIS组件无法打开的解决办法
作者:朱金灿 来源:http://blog.csdn.net/clever101 同事使用VS打开一个C#工程,出现下面的错误: 这个工程是C#的桌面工程,跟IIS无关,去安装IIS太麻烦了.我想到一 ...
- 腾讯云服务器CVM购买详细过程 选择我们需要的腾讯云服务器
腾讯云服务商有云服务器.云数据库.CDN.云存储等产品,其中较多的用户会选择腾讯云服务器,因为用途比较广泛,比如用来软件的运行以及网站建设,如今一般都是用云服务器,而不是用虚拟主机,毕竟虚拟主机的性价 ...
- 2018.6.29 JavaScript
一.使用JS数组实现冒泡排序 二.创建Teacher对象,添加(姓名.年龄.地址.学生对象[学生姓名,学生性别])属性 要求: 创建多个老师对象,每个老师下管理多个学生,显示每个老师下所有的学生信息 ...
- edge不能上网-代码 INET_E_RESOURCE_NOT_FOUND
这个问题 ,网上有很多解决方法,我基本都测试了一遍,可是我都没有用 情况:首先,我开始的时候是可以用的,然后在公司,开了代理,就不能使用了,这是我之后多次尝试发现的,所以你也遇到和我一样的情况不必惊慌 ...