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

如何设计网站建设方案163网易免费邮箱

如何设计网站建设方案,163网易免费邮箱,小米网络营销案例分析,外贸论坛有哪些平台最近面试,发现要手撕算法加上机试,被完败,索性给自己立一个目标,一周训练2次。 第一题。 给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。 …

最近面试,发现要手撕算法加上机试,被完败,索性给自己立一个目标,一周训练2次。

第一题。

给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。

算法的时间复杂度应该为 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
  • -10^6 <= nums1[i], nums2[i] <= 10^6

这题力扣第四题,我看着简单,内容还可以一下子接受.想了快三个小时。

double get_mid(int* nums,int numsSize)
{if(numsSize%2){return nums[numsSize/2];}else{return (nums[numsSize/2]+nums[(numsSize)/2-1])*1.0/2;}
}double findMedianSortedArrays(int* nums1, int nums1Size, int* nums2, int nums2Size) {if((nums1Size==0)&&(nums2Size==0)) return 0;else if((nums1Size==0)&&(nums2Size!=0)){return get_mid(nums2,nums2Size);}else if((nums2Size==0)&&(nums1Size!=0)){return get_mid(nums1,nums1Size);}else{if(nums1[nums1Size-1] <=nums2[0]){int len = nums1Size+nums2Size ;int mid_index = len /2;if(len % 2 ) // 长度是奇数{if(mid_index >= nums1Size){return nums2[nums2Size-mid_index-1];}else{return nums1[mid_index]*1.0;}}else  //长度是偶数{if(mid_index < nums1Size){return (nums1[mid_index]+nums1[mid_index-1])*1.0/2;}else if((mid_index) == nums1Size){return (nums1[nums1Size-1]+nums2[0])*1.0/2;}else{return (nums2[nums2Size-mid_index-1]+nums2[nums2Size-mid_index])*1.0/2;}}}else if(nums2[nums2Size-1] <=nums1[0]){int len = nums1Size+nums2Size ;int mid_index = len /2;if(len % 2 ) //长度是奇数{if(mid_index >= nums2Size){return nums1[nums1Size-mid_index-1];}else{return nums2[mid_index];}}else //长度是偶数{if(mid_index < nums2Size){return (nums2[mid_index]+nums2[mid_index-1])*1.0/2;}else if((mid_index) == nums2Size){return (nums1[0]+nums2[nums2Size-1])*1.0/2;}else{return (nums1[nums1Size-mid_index-1]+nums1[nums1Size-mid_index])*1.0/2;}}}else{int len = nums1Size+nums2Size ;int mid_index = len /2;int count =0;int _n1 = 0,_n2=0;int last=0,midv=0;while(true){if(_n1 == nums1Size) {midv=nums2[_n2];count++;if(count == mid_index+1){if(len%2){return midv*1.0;}else{return (last+midv)*1.0/2;} }_n2++;last = midv;}else if(_n2 == nums2Size) {midv=nums1[_n1];count++;if(count == mid_index+1){if(len%2){return midv*1.0;}else{return (last+midv)*1.0/2;} }_n1++;last = midv;}else{if(nums1[_n1] >= nums2[_n2]){midv = nums2[_n2];count++;if(count == mid_index+1){if(len%2){return midv*1.0;}else{return (last+midv)*1.0/2;}}_n2++;last = midv;}else{midv = nums1[_n1];count++;if(count == mid_index+1){if(len%2){return midv;}else{return (last+midv)*1.0/2;}}_n1++;last = midv;}}}}}}

写的很烂很长,就是没有做过算法题目的人的思维,用了很多特殊情况来提高运算速度,其实把最后一个else提取出来也可以进行运算。但不知道为什么内存消耗很高。

http://www.yayakq.cn/news/303187/

相关文章:

  • 网页设计师学习网站免费网站在线观看
  • 桂林餐饮兼职网站建设网站建设的项目亮点怎么写
  • 做传媒网站公司名称在线制作文字
  • 企业网站建设可行性分析表德州网站制作公司
  • 天津平台网站建设制作seo 优化
  • 网页设计模板html代码素材seo顾问服务 品达优化
  • 论企业网站职能建设wordpress友情链接代码
  • 盐城建设公司网站wordpress会员功能主题
  • 网站开发前端网站导航设计应注意哪些问题
  • 转业做网站的工具招代理网站建设公司
  • 诚信通网站怎么做外链国内好的网站建设
  • 网站制作用的软件苏州做网站公司电话
  • 灰色网站怎么做seo网站建设人员性格特点
  • 2021手机能看的网站寻找做网站的合作伙伴北京
  • 网站制作公司属于广告发布者吗电子上网站建设与维护
  • 泉州北京网站建设网页设计计划怎么写
  • 防疫站24小时在线咨询中国建设网官方网站狗年纪念币
  • 网站建设类的职位成都住房和城乡建设厅官网
  • 静安网站建设公司阿里云建站保证销售额
  • wordpress修改站标在哪个文件新开元电销系统
  • 深圳做网站专业wordpress缩略图配置
  • 企业自适应网站制作江西省外省建设入库网站
  • 后端开发技术有哪些seo网站优化工具大全
  • 网站开发 浏览器兼容性做网站多少费用
  • 用户研究 网站网站选服务器文件
  • 网站开发研究方法企业营销型企业网站建设
  • 南昌市建设工程质量监督站网站如何优化
  • 青州做网站电话wordpress招聘插件
  • 网站切图烟台网站公司
  • 融安有那几个网站做的比较好的无极网站建设质量