二分法简单示例

Java二分法简单示例

首先进行二分法必须得是有序的数组,如果是无序数组,那么先进行排序,再用二分法解决。

package com.etime.test007;

import java.util.Arrays;

//例:结合二分查找法在数组{1,3,2,4,5,7,6}中取出数字3
public class Test01 {
	public static void main(String[] args) {
		// 必须先进行排序再进行二分法
		int[] array = { 1, 3, 2, 4, 5, 7, 6 };
		int len = array.length;
		int temp = 0;
		
		for (int i = 0; i < len - 1; i++) {
			for (int j = 0; j < len - i - 1; j++) {
				if (array[j] > array[j + 1]) {
					temp = array[j + 1];
					array[j + 1] = array[j];
					array[j] = temp;
				}
			}
		}
		System.out.println(Arrays.toString(array));
		// k为要取的值。
		int k = 3;
		// 定义能取到k的最大值为长度减一。
		int max = len - 1;
		// 定义最小值是0。
		int min = array[0];
		// 有序数组的中间值为最小值加上最大值除以二。
		int mid = (min + max) / 2;
		// while语句如果满足要取的值不等于中间值,就执行while语句。
		while (array[mid] != k) {
			// 如果满足最小值小于等于最大值,继续执行。
			if (min <= max) {
				// 因为前面冒泡排序是从小到大的排序。要取的值小于中间值mid,所以取值在中间值的左边位置,但不能等于中间值,所以mid要减一。
				if (array[mid] > k) {
					max = mid - 1;
					// 同理前面冒泡排序是从小到大的排序。要取的值大于中间值mid,所以取值在中间值的右边位置,也不能等于中间值,所以mid要加一。
				} else if (array[mid] < k) {
					min = mid + 1;
				}
				// 中间值
				mid = (min + max) / 2;

			} else {
				// 当不满足最小值小于最大值时直接输出:数据错误!
				System.out.println("数据错误!");
			}
		}
		// 输出结果
		System.out.println("取值为:" + (mid+1));
	}
}

效果图如下
在这里插入图片描述

以上为示例,还请多多指教。

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

发呆小菜鸟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值