java二分查找递归_java学习之—递归实现二分查找法

/**

* 递归实现二分查找法

* Create by Administrator

* 2018/6/21 0021

* 上午 11:25

**/

class OrdArray{

private long[] a;

private int nElems;

public OrdArray(int max){

this.a = new long[max];

this.nElems = 0;

}

public int size(){

return nElems;

}

public long find(long searchKey){

return recFind(searchKey,0,nElems-1);

}

private long recFind(long searchKey, int lowerBound, int upperBound) {

int curIn = (lowerBound+upperBound)/2;

if(a[curIn] == searchKey){

return a[curIn];

}else if(lowerBound > upperBound){

return 0;

}else {

if(a[curIn] < searchKey){

return recFind(searchKey,curIn+1,upperBound);

}else{

return recFind(searchKey,lowerBound,curIn-1);

}

}

}

public void insert(long value){

int j;

for (j=0; j

if(a[j] > value){

break;

}

}

for (int i = nElems; i > j; i--) {

a[i] = a[i-1];

}

a[j] = value;

nElems++;

}

public void display(){

for (int i = 0; i

System.out.print(a[i] + " ");

}

System.out.println();

}

}

public class BinarySearch {

public static void main(String[] args) {

int maxSize = 100;

OrdArray array = new OrdArray(maxSize);

array.insert(72);

array.insert(90);

array.insert(45);

array.insert(126);

array.insert(99);

array.insert(144);

array.insert(27);

array.insert(135);

array.insert(81);

array.insert(108);

array.insert(9);

array.insert(117);

array.insert(36);

array.display();

int searchKey = 27;

long result = array.find(searchKey);

System.out.println("返回结果:"+result+" (0表示未找到)");

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值