斐波那契查找算法 (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月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
65 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
1月前
|
算法 Java 数据中心
探讨面试常见问题雪花算法、时钟回拨问题,java中优雅的实现方式
【10月更文挑战第2天】在大数据量系统中,分布式ID生成是一个关键问题。为了保证在分布式环境下生成的ID唯一、有序且高效,业界提出了多种解决方案,其中雪花算法(Snowflake Algorithm)是一种广泛应用的分布式ID生成算法。本文将详细介绍雪花算法的原理、实现及其处理时钟回拨问题的方法,并提供Java代码示例。
66 2
|
1月前
|
算法 Java 索引
数据结构与算法学习十五:常用查找算法介绍,线性排序、二分查找(折半查找)算法、差值查找算法、斐波那契(黄金分割法)查找算法
四种常用的查找算法:顺序查找、二分查找(折半查找)、插值查找和斐波那契查找,并提供了Java语言的实现代码和测试结果。
18 0
|
1月前
|
算法 Java 编译器
【递归算法】斐波那契变形问题(C/C++)
【递归算法】斐波那契变形问题(C/C++)
|
3月前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
50 6
|
3月前
|
搜索推荐 算法 Java
经典排序算法之-----选择排序(Java实现)
这篇文章通过Java代码示例详细解释了选择排序算法的实现过程,包括算法的基本思想、核心代码、辅助函数以及测试结果,展示了如何通过选择排序对数组进行升序排列。
经典排序算法之-----选择排序(Java实现)
|
3月前
|
搜索推荐 算法 Java
|
3月前
|
存储 算法 Java
LeetCode经典算法题:打家劫舍java详解
LeetCode经典算法题:打家劫舍java详解
68 2
|
3月前
|
人工智能 算法 Java
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
48 1
|
3月前
|
存储 算法 Java
LeetCode经典算法题:预测赢家+香槟塔java解法
LeetCode经典算法题:预测赢家+香槟塔java解法
57 1