当前位置: 首页 > news >正文

LeetCode - 寻找两个正序数组的中位数

官方链接
给定两个大小分别为 mn 的正序(从小到大)数组 nums1nums2。请你找出并返回这两个正序数组的 中位数 。
算法的时间复杂度应该为 O(log (m+n))

示例 1:

输入:nums1 = [1,3], nums2 = [2]
输出:2.00000
解释:合并数组 = [1,2,3] ,中位数 2

示例 2:

输入:nums1 = [1,2], nums2 = [3,4]
输出:2.50000
解释:合并数组 = [1,2,3,4] ,中位数 (2 + 3) / 2 = 2.5

提示:

  • nums1.length == m
  • nums2.length == n
  • 0 <= m <= 1000
  • 0 <= n <= 1000
  • 1 <= m + n <= 2000
  • -106 <= nums1[i], nums2[i] <= 106

我的答案

class Solution {public double findMedianSortedArrays(int[] nums1, int[] nums2) {int totalLength = nums1.length + nums2.length;int[] nums = new int[totalLength];int i = 0, j = 0;while (i + j < totalLength / 2 + 2) {if (i < nums1.length && j < nums2.length) {if (nums1[i] < nums2[j]) {nums[i + j] = nums1[i];i++;} else {nums[i + j] = nums2[j];j++;}continue;}if (i < nums1.length) {nums[i + j] = nums1[i];i++;continue;}if (j < nums2.length) {nums[i + j] = nums2[j];j++;continue;}break;}if ((totalLength & 1) == 0) {return (double) (nums[totalLength / 2 - 1] + nums[totalLength / 2]) / 2;}return nums[totalLength / 2];}
}

我的题解

应该还可以再简单点,声明的总数组长度只需要两位就行了,中位数只看最中间两位。
好像不要新数组也行,后面再研究下

思路

两个数组已经排好序,分别便利取出两个数组的数相互对比,谁大,谁放到新数组里,然后遍历下一个
有点类似于,归并排序的思想:将两个排序好的子序列合并成一个最终的排序序列

解题过程

1)新建一个大数组,用来存储遍历的值
2)遍历两个数组,对比取出来的数,谁小谁先放,然后谁的索引 + 1
3)大概遍历一半多一个,就停止,因为中位数就是取中间那个数(如果是偶数,就是中间两个数的平均数)
4)最后根据所有数的个数是整数还是奇数进行取值

复杂度

  • 时间复杂度:𝑂(𝑁)
  • 空间复杂度:𝑂(𝑁)
http://www.dtcms.com/a/557256.html

相关文章:

  • 上海网站设计公司 静安沙井建网站
  • VMware17完成克隆ubuntu20.04时IP地址相同的问题
  • 【问题排查】hadoop-shaded-guava依赖问题
  • 百度地图网页版在线使用搜索引擎优化搜索优化
  • 网站优化排名兰州网站建设尚美
  • leetcode 3217 从链表中移除在数组中存在的节点
  • C++音视频就业路线
  • 46-基于STM32的智能宠物屋设计与实现
  • blender实现手柄控制VR视角
  • 八股训练营第 2 天 | HTTP请求报文和响应报文是怎样的,有哪些常见的字段?HTTP有哪些请求方式?GET请求和POST请求的区别?
  • 【LUT技术专题】SVDLUT: 基于SVD优化的3DLUT
  • 阿里云企业邮箱怎么申请宿迁网站建设SEO优化营销
  • Linux文件搜索完全指南:find、locate和通配符使用详解
  • PyTorch:AI时代的深度学习利器
  • Linux:探究HTTP协议
  • linux实现设备驱动-字符型设备驱动
  • 门户网站排版有引导的网站
  • Linux USB 子系统深度解析
  • Linux time function in C/C++【2】
  • 人工智能学习中深度学习之python基础之迭代器、生成器、文件处理和模块等
  • wordpress显示评论数福建企业seo推广
  • 12.C++:模版进阶
  • 大模型训练评估中的交叉验证详解
  • 变更股东怎样在工商网站做公示做网站的收费标准
  • (142页PPT)立白MES解决方案1Wonderware运营管理平台(附下载方式)
  • 机器学习日报10
  • Linux 2.6.10 调度器负载均衡机制深度解析:从理论到实现
  • 访链家网网站开发嘉定房地产网站建设
  • 多商户商城APP源码开发的未来方向:云原生、电商中台与智能客服
  • Liunx线程安全