二分查找

要写一个完备的程序属实不易呀。

采用了迭代式和递归式两种方法实现:

package com.wjy.renren;

public class BinarySearch {
	private static int tag=-1;
	public static void main(String args[]){
		
		
		int[] array={3,6,8,9,12,36,76};
		int num=36;
		binarySearch2(array,num,0,array.length);
		System.out.println(tag);
		System.err.println(binarySearch(array,num));
	}
	/**
	 * 
	 * @param array是有序的数组,在这里是升序排列
	 * @param num
	 * @return
	 */
	private static int binarySearch(int[] array,int num){
		if(array.length<1){
			return -1;
		}
		int begin=0;
		int end=array.length;
		int mid=(begin+end)/2;
		while(mid>=0&&mid<array.length){
			if(array[mid]==num){
				return mid;
			}else if(array[mid]<num&&begin!=end){
				begin=mid+1;
			}else if(array[mid]>num&&begin!=end){
				end=mid-1;
			}else{
				break;
			}
			mid=(begin+end)/2;
			
		}
		return -1;
	}
	/**
	 * 采用递归的方式实现
	 * @param array是有序的数组,在这里是升序排列
	 * @param num
	 * @return
	 */
	private static void binarySearch2(int[] array,int num,int begin,int end){
		if(array.length<1){
			return;
		}
		int mid=(begin+end)/2;
		if(array[mid]==num){
			tag=mid;
			return;
		}
		else{
			if(mid==0||mid==array.length-1||begin==end){
				return;
			}
			if(array[mid]>num)
			{
				binarySearch2(array, num, begin, mid-1);
			}
			else{
				binarySearch2(array, num, mid+1, end);
			}
		}
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值