在两个长度相等的排序数组中找到上中位数

这里写图片描述

import java.util.*;
//在两个长度相等的排序数组中找到上中位数
public class FindShangMidNum{

    //找到两个数组的上中位数
    public static int getShangMidNum(int[]arr1,int[]arr2)
    {
        if((arr1==null&&arr2==null)||(arr1.length==0&&arr2.length==0)){
             throw new RuntimeException("Your arr is invalid!");
        }else if(arr1==null||arr1.length==0){
            int temp=0;
            if((arr2.length&1)==0) //偶数
            {
                temp=arr2[arr2.length/2-1];
            }else{
                temp=arr2[arr2.length/2];
            }
            return temp;

        }else if(arr2==null||arr2.length==0){
            int temp=0;
            if((arr1.length&1)==0) //偶数 
            {
               temp=arr1[arr1.length/2-1];
            }else{
                temp=arr1[arr1.length/2];
            }
            return temp;

        }
        int mid=(arr1.length+arr2.length)/2; //要寻找的中位数
        // int low=0;
        // int arr1Mid=binaryFind(arr1,low,arr1.length-1);
        // int arr2Mid=binaryFind(arr2,low,arr2.length-1);;
        // System.out.println(arr1Mid);
        // System.out.println(arr2Mid);
        int re=0;
        int count=arr1.length+arr2.length;
        int[]arr=new int[count];

        for(int i=0;i<arr1.length;i++)
        {
          arr[i]=arr1[i];
          arr[arr.length-1-i]=arr2[i];
        }
        Arrays.sort(arr);
        return arr[arr.length/2-1];
    }

    //方法二(二分查找法)
    public static int getShangMidNum02(int[]arr1,int[]arr2)
    {
      if((arr1==null&&arr2==null)||(arr1.length==0&&arr2.length==0)){
             throw new RuntimeException("Your arr is invalid!");
        }else if(arr1==null||arr1.length==0){
            int temp=0;
            if((arr2.length&1)==0) //偶数
            {
                temp=arr2[arr2.length/2-1];
            }else{
                temp=arr2[arr2.length/2];
            }
            return temp;

        }else if(arr2==null||arr2.length==0){
            int temp=0;
            if((arr1.length&1)==0) //偶数 
            {
               temp=arr1[arr1.length/2-1];
            }else{
                temp=arr1[arr1.length/2];
            }
            return temp;

        }
      int start1=0;
      int end1=arr1.length-1;
      int start2=0;
      int end2=arr2.length-1;
      int mid1=0;
      int mid2=0;
      int offset=0;
      while(start1<end1){

         mid1=(start1+end1)/2;
         mid2=(start2+end2)/2;
         //元素个数为奇数,offset=0;元素个数为偶数,则offset=1
         offset=((end1-start1+1)&1)^1;
         if(arr1[mid1]>arr2[mid2]){
            end1=mid1;
            start2=mid2+offset;
         }else if(arr1[mid1]<arr2[mid2]){
            start1=mid1+offset;
            end2=mid2;
         }else{
            return arr1[mid1];
         }
      }
      return Math.min(arr1[start1],arr2[start2]);
    }
    public  static void main(String[]args){

        //System.out.println("Hello");
        int[]arr1={1,2,3,4};
        int[]arr2={3,4,5,6};
        //int[]arr2={};
        System.out.println(getShangMidNum(arr1,arr2));
        System.out.println(getShangMidNum02(arr1,arr2));
        int[]arr3={0,1,2};
        int[]arr4={3,4,5};
        System.out.println(getShangMidNum(arr3,arr4));
        System.out.println(getShangMidNum02(arr3,arr4));


    }
}

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
VBSCRIPT中文手册,这里的信息可以帮你很方便地浏览 Visual Basic 脚本的许多不同部分。 你可以找到在按字母排序的关键字列表中列出的 VBScript 语言的所有部分。如果你只想调阅某一部分,例如“对象”,那么语言的每一部分都有它自己更严密的章节。 如何查找呢?单击左边的某个标题,即显示该部分中包含的项目列表。从这张列表中选择要查看的主题。当这个主题打开后,再链接到其他相关的部分就简单多了。 好了,让我们试一试,体会体会!学习几个语句,研究几种方法,或者熟悉几个函数。你就能学会如何巧妙地运用 VBScript 语言,充分发挥 VBScript 语言的强大功能。 特性 说明 VBScript 特性 VBScript 最新特性列表 未包含在 VBScript 中的 VBA 特性 VBScript 最新特性列表:未包含在 VBScript 中的应用程序编辑。 未包含在 VBA 中的 VBScript 特性 未包含在 Visual Basic 中的 VBScript 特性列表:应用程序编辑。 Microsoft Scripting 运行时特性 VBScript 中最新的 Scripting 运行时特性列表。 语言元素 说明 Abs 函数 返回数的绝对值。 加法运算符 (+) 两数相加。 And 运算符 执行两个表达式的逻辑连接。 Array 函数 返回含一数组的 变体 。 Asc 函数 返回字符串首字母的 ANSI 字符代码。 赋值运算符 (=) 给变量或属性赋值。 Atn 函数 返回数的反正切值。 调用语句 将控制移交 Sub 或 Function 过程。 CBool 函数 返回已被转换为 Boolean 子类型的变体的表达式。 CByte 函数 返回已被转换为字节子类型的变体的表达式。 CCur 函数 返回已被转换为货币子类型的变体的表达式。 CDate 函数 返回已被转换为日期子类型的变体的表达式。 CDbl 函数 返回已被转换为双精度子类型的变体的表达式。 Chr 函数 返回指定 ANSI 字符码的字符。 CInt 函数 返回已被转换为整数子类型的变体的表达式。 Class 对象 提供对已创建的类的事件的访问。 Class 语句 声明类名 Clear 方法 清除 Err 对象的所有属性设置。 CLng 函数 返回已被转换为 Long 子类型的变体的表达式。 颜色常数 颜色常数列表。 比较常数 用于比较运算的常数列表。 连接运算符 (&) 强制两个表达式的字符串连接。 Const 语句 声明用于字母值的常数。 Cos 函数 返回角度的余弦值。 CreateObject 函数 创建并返回对“自动”对象的引用。 CSng 函数 返回已被转换为单精度子类型的变体的表达式。 CStr 函数 返回已被转换为字符串子类型的变体的表达式。 日期和时间常数 在日期和时间运算中用来定义星期几和其他常数的常数列表。 日期格式常数 用于日期和时间格式的常数列表。 Date 函数 返回当前系统日期。 DateAdd 函数 返回加上了指定的时间间隔的日期。 DateDiff 函数 返回两个日期之间的间隔。 DatePart 函数 返回给定日期 的指定部分。 DateSerial 函数 返回指定年月日的 日期子类型的变体 。 DateValue 函数 返回日期子类型的变体 。 Day 函数 返回日期,取值范围为 1 至 31。 Description 属性 返回或者设置说明某个错误的字符串。 Dictionary 对象 存储数据键、项目对的对象。 Dim 语句 声明变量并分配存储空间。 除法运算符 (/) 两数相除并以浮点数格式返回商。 Do...Loop 语句 当条件为 True 或者当条件变为 True 时,重复一语句块。 Empty 表示尚未初始化的变量值。 Eqv 运算符 使两个表达式相等。 Erase 语句 重新初始化固定数组的元素并重新分配动态数组的存储空间。 Err 对象 含有关于运行时错误的信息。 Eval 函数 计算并返回表达式的值。 Execute 方法 根据指定的字符串,执行正则表达式的搜索。 Execute 语句 执行单个或更多的指定语句。 Exit 语句 退出 Do...Loop、For...Next、 Function 或 Sub 代码块。 Exp 函数 返回 e (自然对数的底)的多少次方。 自乘运算符 (^) 指数函数,幂为自变量。 False 关键字,其值为零。 FileSystemObject 对象 提供对计算机文件系统的访问。 Filter 函数 根据指定的筛
### 回答1: 中位数是指将一个集合分为两个长度相等的子集,其中一个子集中的元素总是大于另一个子集中的元素。对于给定的两个正序数组,可以将它们合并成一个有序数组,然后找到这个有序数组中位数。 如果两个数组长度之和为奇数,中位数就是有序数组中间的那个元素;如果长度之和为偶数,中位数就是有序数组中两个元素的平均值。 具体实现可以使用归并排序的思想,将两个数组合并成一个有序数组,然后根据长度之和的奇偶性找到中位数。时间复杂度为 O(m+n)。 ### 回答2: 题目描述 给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2,请你找出并返回这两个正序数组中位数。 示例 示例1: 输入: nums1 = [1,3] nums2 = [2] 输出:2 示例2: 输入: nums1 = [1,2] nums2 = [3,4] 输出:2.5 解释: 合并数组后为 [1,2,3,4],中位数为 (2 + 3) / 2 = 2.5 解法 由于已知nums1和nums2都是正序,所以我们可以分别尝试对两个数组进行二分查找找到两个数组中位数对应的位置。 首先,选定两个数组中位数的位置: - 对于一个长度为n的正序数组中位数的位置可以是n/2,也可以是(n-1)/2,因为n/2就是中位数所在的位置,但(n-1)/2和n/2的结果是一样的,因为这两个位置对应的两个数的差值对中位数的影响是一样的。 - 所以对于长度为m的nums1和长度为n的nums2,选定中位数的位置应该是(m+n+1)/2和(m+n+2)/2两个位置。 然后,我们对nums1进行二分查找找到一个位置i,使得: nums1[i-1] <= nums2[j] && nums2[j-1] <= nums1[i] 我们可以将这个位置i称为“分割线”,分割线左边的元素可以组成一个长度为i+j-1的有序数组,右边的元素可以组成一个长度为m+n-i-j+1的有序数组。 对于奇数的情况,中位数就是分割线左边的元素和分割线右边的元素中较大的那个。 对于偶数的情况,中位数就是分割线左边的元素和分割线右边的元素的平均数。 代码 ### 回答3: 首先,我们需要了解中位数的定义。中位数是一组数据中居于中间位置的数,即把一组数从小到大或从大到小排序后,位于中间位置(如果有偶数个数,则取中间两个数的平均值)的数字。因此,要求解这两个正序数组中位数,我们需要先将它们合并成一个有序数组,然后找出中间位置的数或两个数的平均值。 合并两个有序数组的方法有很多种,这里介绍一种比较简单的方法:使用双指针法,分别指向两个数组的起始位置,逐个比较两个指针所指的数,将较小的数存入一个新数组中,并将指针后移,直到任意一个数组的数被取完,再将剩余的数组中的数依次存入新数组中。最终得到的新数组就是合并后的有序数组。 接下来,我们需要确定中位数的位置。假设两个有序数组长度分别为 m 和 n,那么它们的中位数要么是第 (m+n)/2 个数,要么是第 (m+n)/2 和 (m+n)/2+1 个数的平均值(当 m+n 为偶数时)。 因此,我们可以使用双指针法,同时遍历两个有序数组,记录已经遍历的数的个数,当遍历到第 (m+n)/2 或 (m+n)/2+1 个数时,就可以得到中位数。 下面是使用双指针法求解两个有序数组中位数Python 代码实现: ```python class Solution: def findMedianSortedArrays(self, nums1: List[int], nums2: List[int]) -> float: m, n = len(nums1), len(nums2) nums = [] i, j = 0, 0 while i < m and j < n: if nums1[i] < nums2[j]: nums.append(nums1[i]) i += 1 else: nums.append(nums2[j]) j += 1 nums += nums1[i:] nums += nums2[j:] k = (m + n) // 2 if (m + n) % 2 == 0: return (nums[k-1] + nums[k]) / 2 else: return nums[k] ``` 该算法的时间复杂度为 O(m+n),空间复杂度为 O(m+n)。需要注意的是,由于 Python 中整数除法运算会向下取整,因此计算中位数位置时需要使用 (m+n)//2 和 (m+n)//2+1。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值