完整代码如下:
package com.wqc.search;
import java.util.Arrays;
/**
* @author 高瞻远瞩
* @version 1.0
* @motto 算法并不可怕, 可怕的是你不敢面对它, 加油!别浮躁~冲击大厂!!!
* 插值查找算法 基于二分查找的改进 也要求数组是有序的 自适应
* mid = left + (right - left)*(findValue - arr[left])/(arr[right] - arr[left])
*/
public class InsertValueSearch {
public static void main(String[] args) {
int[] arr = new int[100];//先创建一个1~100的数组
for (int i = 0; i < arr.length; i++) {
arr[i] = i + 1;
}
int i = insertValueSearch(arr, 0, arr.length - 1, 2);
if(i != -1){
System.out.println("找到 下标=" + i);//只输出了一次hello
}else{
System.out.println("没有找到");
}
// System.out.println(Arrays.toString(arr));
}
public static int insertValueSearch(int[] arr, int left, int right, int findValue) {
System.out.println("hello");
if (left > right || findValue < arr[0] || findValue > arr[arr.length - 1]) {//没找到
return -1;
}
int mid = left + (right - left) * (findValue - arr[left]) / (arr[right] - arr[left]);
if(findValue > arr[mid]){//右递归
return insertValueSearch(arr,mid + 1,right,findValue);
}else if(findValue < arr[mid]){//左递归
return insertValueSearch(arr,left,mid - 1,findValue);
}else{
return mid;
}
}
}