二分法(二分法找目标数在不在数组中)

二分法(二分法找目标数在不在数组中)

findGoal方法重点
先动首尾,middle才跟着动的

代码:

import java.util.Scanner;
import java.util.Arrays;
public class eightytwo {
	public static void main(String[] args) {
		Scanner reader=new Scanner(System.in);
		String s=reader.nextLine();
		int goal=reader.nextInt();
		String a[]=s.split(" ");
		int[] b=new int[a.length];
		for(int i=0;i<a.length;i++) {
			b[i]=Integer.parseInt(a[i]);
		}
		Arrays.sort(b);
		if(findGoal(0,(a.length-1),goal,b)==1) {
			System.out.println("have");
		}
		if(findGoal(0,(a.length-1),goal,b)==0) {
			System.out.println("not have");
		}
	}
	public static int findGoal(int a,int b,int g,int[] arr) {
		int min=a;int max=b;
		while(min<=max) {
			int mid=(max+min)/2;
			if(arr[mid]==g) {
				return 1;
			}
			else if(arr[mid]<g) {
				min=mid+1;
			}
			else {
				max=mid-1;
			}
		}
		return 0;
	}
}
/*
1 2 3 4 66
23

 */

运行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值