[转载]寻找两个有序数组中的第K个数或者中位数
http://blog.csdn.net/realxie/article/details/8078043
假设有长度分为为M和N的两个升序数组A和B,在A和B两个数组中查找第K大的数,即将A和B按升序合并后的第K个数。
解法一:
使用两个指针指向A和B的开头,很容易在O(M+N)的时间内完成,此算法略过。
解法二:
使用二分的方法。算法思想在代码注释中
- #include <iostream>
- #include <string.h>
- #include <stdlib.h>
- using namespace std;
- //Notice : K > 0
- int FindKthElm(int A[], int aBeg, int aEnd, int B[], int bBeg, int bEnd, int k)
- {
- if (aBeg > aEnd)
- {
- return B[bBeg + k - 1];
- }
- if (bBeg > bEnd)
- {
- return A[aBeg + k - 1];
- }
- //取中间位置
- int aMid = aBeg + (aEnd - aBeg)/2;
- int bMid = bBeg + (bEnd - bBeg)/2;
- //从A和B的开始位置到两个数组中间位置的元素个数
- int halfLen = aMid - aBeg + bMid - bBeg + 2;
- if (A[aMid] < B[bMid])
- {
- if (halfLen > k)
- {
- // 此时在合并的数组中A[aBeg...aMid]和元素一定在B[bMid]的左侧,
- // 即此时第k大的元素一定比B[bMid]这个元素小(严格来说不大于)
- // 故以后没有必要搜索 B[bMid...bEnd]这些元素
- return FindKthElm(A, aBeg, aEnd, B, bBeg, bMid - 1, k);
- }
- else
- {
- // 此时在合并的数组中A[aBeg...aMid]元素一定在B[bMid]的左侧,
- // 所以前K个元素中一定包含A[aBeg...aMid](可以使用反证法来证明这点)。
- // 但是无法判断A[amid+1...aEnd]与B[bBeg...bEnd]之间的关系,帮需要对他们进行判断
- // 此时K就剩下除去A[aBeg...aMid]这些元素,个数为k - (aMid - aBeg + 1)
- return FindKthElm(A, aMid + 1, aEnd, B, bBeg, bEnd, k - (aMid - aBeg + 1));
- }
- }
- else
- {
- //注释与上面相似
- if (halfLen > k)
- {
- return FindKthElm(A, aBeg, aMid - 1, B, bBeg, bEnd, k);
- }
- else
- {
- return FindKthElm(A, aBeg, aEnd, B, bMid + 1, bEnd, k - (bMid - bBeg + 1));
- }
- }
- }
- int main()
- {
- const int ALen = 11;
- const int BLen = 5;
- int apos = 0;
- int bpos = 0;
- int A[ALen];
- int B[ALen];
- //生成两个递增数组A 和 B
- for (int i = 1; i <= ALen + BLen; ++i)
- {
- if (apos >= ALen)
- {
- B[bpos++] = i;
- }
- else if (bpos >= BLen)
- {
- A[apos++] = i;
- }
- else
- {
- if (rand()%2 == 1)
- {
- A[apos++] = i;
- }
- else
- {
- B[bpos++] = i;
- }
- }
- }
- //输出A和B的内容
- for (int i = 0; i < ALen; ++i)
- {
- cout <<A[i] <<" ";
- }
- cout <<endl;
- for (int i = 0; i < BLen; ++i)
- {
- cout <<B[i] <<" ";
- }
- cout <<endl;
- //验证每个K是不是正解
- for (int i = 1; i <= ALen + BLen; ++i)
- {
- cout << i <<" : "<<FindKthElm(A, 0 , ALen - 1, B, 0 , BLen - 1, i)<<endl;
- }
- return 0;
- }
[转载]寻找两个有序数组中的第K个数或者中位数的更多相关文章
- 查找两个有序数组中的第K个元素(find kth smallest element in 2 sorted arrays)
查找两个有序数组中的第K个元素 int FindKth(int a[], int b[], int k, int astart, int aend, int bstart, int bend) { ; ...
- 选取两个有序数组中最大的K个值,降序存入另一个数组中
原题: 假设有两个有序的整型数组int *a1, int *a2,长度分别为m和n.试用C语言写出一个函数选取两个数组中最大的K个值(K可能大于m+n)写到int *a3中,保持a3降序,并返回a3实 ...
- 两个有序数组中查找第K大数
题目:两个数组A.B,长度分别为m.n,即A(m).B(n),分别是递增数组.求第K大的数字. 方法一: 简单的办法,使用Merge Sort,首先将两个数组合并,然后在枚举查找.这个算法的时间复 ...
- Java实现 LeetCode 4 寻找两个有序数组的中位数
寻找两个有序数组的中位数 给定两个大小为 m 和 n 的有序数组 nums1 和 nums2. 请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n)). 你可以假设 n ...
- 寻找两个有序数组的中位数 C++实现leetcode系列(四)
给定两个大小为 m 和 n 的有序数组 nums1和 nums2. 请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n)). 你可以假设 nums1 和 nums2 不 ...
- Coursera Algorithms week3 快速排序 练习测验: Selection in two sorted arrays(从两个有序数组中寻找第K大元素)
题目原文 Selection in two sorted arrays. Given two sorted arrays a[] and b[], of sizes n1 and n2, respec ...
- LeetCode Golang 4. 寻找两个有序数组的中位数
4. 寻找两个有序数组的中位数 很明显我偷了懒, 没有给出正确的算法,因为官方的解法需要时间仔细看一下... func findMedianSortedArrays(nums1 []int, nums ...
- 两个有序数组中的中位数以及求第k个最小数的值
解法参考 <[分步详解]两个有序数组中的中位数和Top K问题> https://blog.csdn.net/hk2291976/article/details/51107778 里面求中 ...
- 0004. 寻找两个有序数组的中位数(Java)
4. 寻找两个有序数组的中位数 https://leetcode-cn.com/problems/median-of-two-sorted-arrays/ 最简单的就是用最简单的,把两个数组分别抽出然 ...
随机推荐
- C#函数式编程之递归调用
关于递归相信大家已经熟悉的不能再熟悉了,所以笔者在这里就不多费口舌,不懂的读者们可以在博客园中找到很多与之相关的博客.下面我们直接切入正题,开始介绍尾递归. 尾递归 普通递归和尾递归如果仅仅只是从代码 ...
- C/C++文件操作1
在C语言中,文件操作都是由库函数来完成的. 在本章内将介绍主要的文件操作函数. 文件打开函数fopen fopen函数用来打开一个文件,其调用的一般形式为:文件指针名=fopen(文件名,使用文件方式 ...
- paip. 混合编程的实现resin4 (自带Quercus ) 配置 php 环境
paip. 混合编程的实现resin4 (自带Quercus ) 配置 php 环境 #---混合编程的类型 1.代码inline 方式 2.使用库/api 解析方式. #----配置resin 支 ...
- SHINY-SERVER R(sparkR)语言web解决方案 架设shiny服务器
1. shiny server简介 shiny-server是一种可用把R 语言以web形式展示的服务,其实RStudio公司自己构建了R Shiny Application运行的平台(http:// ...
- JAVA学习中Swing部分JDialog对话框窗体的简单学习
package com.swing; import java.awt.Color;import java.awt.Container;import java.awt.event.ActionEvent ...
- android eclipse关联源码,以及源码(代码)以及jar查看软件
1.eclipse关联源码 步骤一:自已百度下载相应版本的源码,我这里是4.2也就是API=17的版本. 步骤二:找到你安装sdk的目录, G:\Program Files\adt-bundle-wi ...
- React访问组件元素的子元素(ES5与ES6的对比)
// 创建组件var NewDom = React.createClass({ // 类名一定要大写开头 render: function () { return ( <ol> { Rea ...
- PHP中常用的正则表达式由哪些元素构成?
在程序开发中,我们常常要用到正则表达式,对于新手来说,很多时候知道正则表达式是怎么回事,但当真正需要使用的时候,却不知该用什么函数,具体的修饰符也比较混乱.下面小编就为大家整理了一些php正则表达式中 ...
- 写hive db的两种方法
方法1tmp_channel_hive_file="/tmp/tmp_channel_hive_file"tmp_channel_hive_file_new="/tmp/ ...
- Python操作Excel
一.系统性学习 对于操作Excel,需要Xlrd/xlwt这两个模块,下面推荐出系统性学习的网址: python操作Excel读写--使用xlrd 官方文档 Python 使用 Xlrd/xlwt 操 ...