java二分查找

算法书第一个程序,二分查找

代码如下

public class BinarySearchSecond {
	public static void main(String[] args) {
		 int[] a = {12,23,45,1,5,89,45,123,18};
		 Arrays.sort(a);
		 for(int b : a) {
			 System.out.print(b+",");
		 }
		 Boolean flag = BianrySearch(13,a);
		 System.out.println(flag);
	}

	private static Boolean BianrySearch(int i,int[] a) {
		 if(i<a[0]||i>a[a.length-1]) {
			 return false;
		 }else if(i==a[0] || i== a[a.length-1]) {
			 return true;
		 }else {
			 int head = 0;
			 int tail = a.length-1;
			 while(head<tail) {
				 int mid = (head + tail)/2+1;
				 if(i>a[mid]) {
					 head = mid+1;
				 }else if(i<a[mid]) {
					 tail = mid-1;
				 }else {
					 return true;
				 }
			 }
		 }
		 return false;
	}
}

想算法还是用笔,用一个例子在纸上写下来比较好。起码思路清晰

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值