JAVA数据结构与算法的学习——折半查找和插值插值

折半查找又称二分查找,前提是线性表中的记录必须是关键码有序(通常从小到大有序)

思路图解:
在这里插入图片描述
在这里插入图片描述

实现代码:

public class Test {

	static int Binary_search(int[] a, int key) {
		int low; // 定义最低位下标
		int high; // 定义最高位下标
		int mid; // 中间位

		low = 0;
		high = a.length - 1;
		int count = 0;
		while (low <= high) {
			mid = (low + high) / 2;
			if (key < a[mid]) {
				high = mid - 1;
				count++;
			} else if (key > a[mid]) {
				low = mid + 1;
				count++;
			} else {
				System.out.println("count=" + count);
				return mid;
			}
		}
		return -1;
	}

	public static void main(String[] args) {
		int a[] = new int[1000];
		int key = 3;
		for (int i = 1; i < 1000; i++) {
			a[i] = i;
		}
		System.out.println(a[Binary_search(a, key)]);
	}

}

输出结果:

count=9
3

经过九次查找到目标值3

接下来是插值插值,其最大的核心mid的计算改变了

代码:

public class Test {

	static int Binary_search(int[] a, int key) {
		int low; // 定义最低位下标
		int high; // 定义最高位下标
		int mid; // 中间位

		low = 0;
		high = a.length - 1;
		int count = 0;
		while (low <= high) {
			 mid = low+(high-low)*(key-a[low])/(a[high]-a[low]); //插值
			if (key < a[mid]) {
				high = mid - 1;
				count++;
			} else if (key > a[mid]) {
				low = mid + 1;
				count++;
			} else {
				System.out.println("count=" + count);
				return mid;
			}
		}
		return -1;
	}

	public static void main(String[] args) {
		int a[] = new int[1000];
		int key = 899;
		for (int i = 1; i < 1000; i++) {
			a[i] = i;
			System.out.println(a[i]);
		}
		System.out.println(a[Binary_search(a, key)]);
	}

}

结果:

count=0
899

直接就找到了,有点强

如果关键字分布比较均匀的查找表来说,插值查找算法的平均性能会比折半查找好得多,反之如果分布是比较极端不均匀的,用插值查找未必是很适合的选择。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值