斐波那契查找算法 (java)

简介: 斐波那契查找算法 (java)

类似二分查找,mid取值按照黄金分割比取,斐波那契数组最接近黄金分割比数组。

 
 
import java.util.Arrays;
 
public class FibonacciSearch {
    public static void main(String[] args) {
        int[] arr = {1, 8, 10, 89, 1000, 1234};
        int[] fib = fib(20);
        System.out.println(Arrays.toString(fib));
        System.out.println(fibSearch(arr,1234));
    }
 
    /**
     * 获取斐波那契数列
     */
    public static int[] fib(int size) {
        int[] arr = new int[size];
        for (int i = 0; i < size; i++) {
            if (i == 1 || i == 0) {
                arr[i] = 1;
            } else {
                arr[i] = arr[i - 1] + arr[i - 2];
            }
        }
        return arr;
    }
 
    /**
     * 斐波那契查找算法
     *
     * @param arr 数组
     * @param key 查找的值
     * @return 返回对相应下标,默认返回-1;
     */
    public static int fibSearch(int[] arr, int key) {
        int low = 0;
        int hight = arr.length - 1;
        //斐波那契数组的下标
        int k = 0;
        //存放mid值
        int mid = 0;
        int[] fibArr = fib(arr.length);
        //获取斐波那契分割数值的下标
        while (hight > fibArr[k] - 1) {
            k++;
        }
        //fibArr[k]的值可能大于a的长度,需要扩充,新增的值用原数组最大值
        int[] temp = Arrays.copyOf(arr, fibArr[k]);
        for (int i = arr.length; i < fibArr[k]; i++) {
            temp[i] = arr[arr.length - 1];
        }
        //使用while寻找key
        while (low <= hight) {
            mid = low + fibArr[k - 1] - 1;
            //fibArr[k]=fibArr[k-1]+fibArr[k-2];
            //全部元素=前边的元素+后边的元素
            //前边k-1 后边k-2
            if (key < temp[mid]) {
                hight = mid - 1;
                k--;
            }else if(key>temp[mid]){
                low=mid+1;
                k-=2;
            }else{
                if(mid>hight){
                    return hight;
                }else{
                    return mid;
                }
            }
        }
        return -1;
    }
}
相关文章
|
1月前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
38 6
|
1月前
|
搜索推荐 算法 Java
经典排序算法之-----选择排序(Java实现)
这篇文章通过Java代码示例详细解释了选择排序算法的实现过程,包括算法的基本思想、核心代码、辅助函数以及测试结果,展示了如何通过选择排序对数组进行升序排列。
经典排序算法之-----选择排序(Java实现)
|
1月前
|
搜索推荐 算法 Java
|
1月前
|
存储 算法 Java
LeetCode经典算法题:打家劫舍java详解
LeetCode经典算法题:打家劫舍java详解
52 2
|
1月前
|
人工智能 算法 Java
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
39 1
|
1月前
|
存储 算法 Java
LeetCode经典算法题:预测赢家+香槟塔java解法
LeetCode经典算法题:预测赢家+香槟塔java解法
37 1
|
1月前
|
算法 Java
HanLP — HMM隐马尔可夫模型 -- 维特比(Viterbi)算法 --示例代码 - Java
HanLP — HMM隐马尔可夫模型 -- 维特比(Viterbi)算法 --示例代码 - Java
31 0
|
1月前
|
搜索推荐 算法 Java
插入排序算法(Java代码实现)
这篇文章通过Java代码示例详细解释了插入排序算法的实现过程,包括算法的基本思想、核心代码、辅助函数以及测试结果,展示了如何通过插入排序对数组进行升序排列。
|
1月前
|
存储 算法 Java
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
64 0
|
1月前
|
算法 Java
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
44 0