分治法求中位数java_分治法求中位数

include

using namespace std;

void Mid(int a[],int aleft,int aright,int b[],int bleft,int bright)

{

double mid;

int n=aright-aleft+1;

int k1=(aleft+aright)/2;

int k2=(bleft+bright)/2;

if(aright-aleft==1&&bright-bleft==1)

{

cout<

return ;

}

if((aleft==aright)&&(bleft==bright))

{

mid=(a[aleft]+b[bleft])/2.0;

cout<

return;

}

else

{

if(a[k1]==b[k2])

{

mid=a[k1];

cout<

}

if(a[k1]

{

Mid(a,k1,aright,b,bleft,k2);

//cout<

}

if(a[k1]>b[k2])

{

Mid(a,aleft,k1,b,k2,bright);

//cout<

}

}

}

int main()

{

int a[]={1, 12, 15, 26, 38};

int b[]={13, 14, 40, 42, 45};

Mid(a,0,4,b,0,4);

system("pause");

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值