斐波那契查找算法

//斐波那契查找算法

public class FibonacciSearch {

public static void main(String[] args) {

// TODO Auto-generated method stub

// 需要查找的顺序表

int arr[] = { 1, 4, 8, 14, 78, 90 };

// 斐波那契数列

//int[] f = f();

//System.out.println(Arrays.toString(f));

int fibonacci = fibonacci(arr,90);

System.out.println(fibonacci);

}

// 构造一个斐波那契数列

public static int[] f() {

int[] flb = new int[20];

flb[0] = 1;

flb[1] = 1;

for (int i = 2; i < flb.length; i++) {

flb[i] = flb[i - 1] + flb[i - 2];

}

return flb;

}

//

public static int fibonacci(int a[], int key) {

int low = 0;

int high = a.length - 1;

int k = 0;

int[] f = f();

int mid = 0;

// 如果这个顺序表的数组小于 斐波那契数列的k下标值的 长度 就自动增加

while (high > f[k] - 1) {

k++;

}

// 将a扩容 到f[k]的长度 多出来的长度肯定会被0补充

int[] temp = Arrays.copyOf(a, f[k]);

// 给多出来的0赋值成 最后一个值

for (int i = high + 1; i < f[k]; i++) {

temp[i] = a[high];

}

while (low <= high) {

// 找到mid点

mid = low + f[k - 1] - 1;

if (key < temp[mid]) {

//查找斐波那契左边一段  即f[k-1]

high = mid - 1;

k--;

} else if (key > temp[mid]) {

//查找斐波那契左边一段  即f[k-2]

low = mid + 1;

k -= 2;

} else {

if (mid <= high) {

return mid;

} else {

return high;

}

}

}

//

return -1;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值