手撸二分查找

知识共享许可协议 版权声明:署名,允许他人基于本文进行创作,且必须基于与原先许可协议相同的许可协议分发本文 (Creative Commons

title: 手撸二分查找
date: 2019-04-20 23:15:55
tags: 二分查找
categories: 算法

手撸二分查找

下面是自己对二分查找的理解,以便日后回顾:

  • 二分查找的前提:内容是有序的
	public static void main(String[] args) {
		int[] arry = new int[] { 1, 8, 10, 50, 60, 80 };
		
		//设置一个标记
		boolean flag=true;
		
		//目标值
		int target = 10;
		
		//头结点
		int head = 0;
		
		//尾结点
		int end = arry.length - 1;
		
		//头结点与尾结点相同的时候查找结束
		while (head <= end) {
			
			//中间结点
			int middle = (head + end) / 2;
			if (target == arry[middle]) {
				System.out.println("位置为" + middle);
		
        		//如果查找成功,标记点为false
				flag=false;
				
				//查找成功,跳出循环标记为false
				break;
				
				//查找值小于中间结点值
			} else if (arry[middle] > target) {
			
				//中间结点减一为尾结点
				end = middle - 1;
				
				//查找值大于中间结点值
			} else {
			
				//中间结点加为头结点
				head = middle + 1;
			}
		}
		
		//标记点为alse就不会显示查找失败
		if(flag) {
			System.out.println("没有找到");
		}
	}

猜你喜欢

转载自blog.csdn.net/qq_39943682/article/details/93472247
今日推荐