查找算法-斐波那契查找法(Fibonacci Search)

news2024/11/15 18:56:57

目录

  查找算法-斐波那契查找法(Fibonacci Search)

1、说明

2、算法分析

3、C++代码 


  查找算法-斐波那契查找法(Fibonacci Search)

1、说明

斐波那契查找法又称为斐氏查找法,此查找法和二分法一样都是以分割范围来进行查找的,不同的是斐波那契查找法不是按对半方式来分割的,而是以斐波那契级数的方式来分割的。

斐波那契级数F(n)的定义如下:

        F_{0} = 0; F_{1} = 1;

        F_{i} = F_{i-1} + F_{i-2}

斐波那契级数:0、1、1、2、3、5、8、13、21、34、55、89、...。也就是除了第0个和第1个元素外,级数中的每个元素值都是前两个元素值的和。

斐波那契查找法的好处是只需要用到加减运算而不需要用到乘除运算,这从计算机运算的过程来看效率会高于前两种查找法。在尚未介绍斐波那契查找法之前,我们先来认识斐波那契树。所谓斐波那契树,是以斐波那契级数的特性来建立的二叉树,其建立的原则如下:

  1. 斐波那契树的左右子树均为斐波那契树。
  2. 当数据个数n确定时,若想确定斐波那契树的层数k值是多少,我们必须找到一个最小的k值,使得斐波那契层数的Fib(k+1)\geqslant n+1
  3. 斐波那契树的树根一定是一个斐波那契树,且子节点与父节点差值的绝对值为斐波那契数。
  4. k\geqslant 2时,斐波那契树的树根为Fib(k),左子树为(k-1)层斐波那契树(其树根为Fib(k-1)),右子树为(k-2)层斐波那契树(其树根为Fib(k)+Fib(k-2))。
  5. n+1值不是斐波那契树的值,则可以找出一个m,使得Fib(k+1)-m=n+1m=Fib(k+1)-(n+1),再按斐波那契树的建立原则完成斐波那契树的建立,最后斐波那契树的各节点再减去差值m即可,并把小于1的节点去掉。

2、算法分析

  1. 斐波那契查找法的平均比较次数少于二分查找法,但在最坏的情况下二分查找法较快,其平均时间复杂度为O(log_{2}n)
  2. 斐波那契查找法较为复杂,需额外产生斐波那契树。

3、C++代码 

#include<iostream>
using namespace std;

void SetData(int* Data, int Size) {
	for (int i = 0; i < Size; i++) {
		Data[i] = rand() % 150 + 1;
	}
}

void Sort(int* Data, int Size) {
	for (int i = 0; i < Size; i++) {
		for (int j = i + 1; j < Size; j++) {
			if (Data[i] > Data[j]) {
				int temp = Data[i];
				Data[i] = Data[j];
				Data[j] = temp;
			}
		}
	}
}

void Print(int* Data, int Size) {
	for (int i = 0; i < Size ; i++) {
		cout << Data[i] << "  ";
	}
	cout << endl;
}

int* Fibonacci(int Size) {
	int* fib = new int[Size];
	fib[0] = 0;
	fib[1] = 1;
	for (int i = 2; i < Size; i++) {
		fib[i] = fib[i - 1] + fib[i - 2];
	}
	return fib;
}

int FibonacciSearch(int* Data, int Size, int Value) {
	int low = 0;
	int high = Size - 1;
	int k = 0;
	int mid = 0;

	int* fib = Fibonacci(Size);

	while (high > fib[k] - 1) {
		k++;
	}
	int* temp = new int[fib[k]];
	for (int i = 0; i < Size; i++) {
		temp[i] = Data[i];
	}
	for (int i = Size; i < fib[k]; i++) {
		temp[i] = Data[high];
	}

	while (low <= high) {
		mid = low + fib[k - 1] - 1;
		if (Value < temp[mid]) {
			high = mid - 1;
			k--;
		}
		else if (Value > temp[mid]) {
			low = mid + 1;
			k -= 2;
		}
		else
			return mid <= high ? mid : high;
	}
	return -1;
}

int main() {
	int Size = 20;
	int* Data = new int[Size] {0};

	SetData(Data, Size);
	Sort(Data, Size);
	cout << "原始数据:" << endl;
	Print(Data, Size);
	cout << "---------------------" << endl;

	int num = 0;
	cout << "请输入想要查找的数据:";
	cin >> num;

	int index = -1;
	index = FibonacciSearch(Data, Size, num);

	if (index != -1)
		cout << "查找的数据在数据库的第[ " << index + 1 << " ]位" << endl;
	else
		cout << "在数据库中没有找到该数据" << endl;

	return 0;
}

输出结果 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1134392.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第12章 PyTorch图像分割代码框架-1

从本章开始&#xff0c;本书将会进行深度学习图像分割的实战阶段。PyTorch作为目前最为流行的一款深度学习计算框架&#xff0c;在计算机视觉和图像分割任务中已经广泛使用。本章将介绍基于PyTorch的深度学习图像分割代码框架&#xff0c;在总体框架的基础上&#xff0c;基于PA…

kuaishou web端did注册激活 学习记录

快手web端 did 注册激活的流程大概如下&#xff1a; 1.访问web端的接口&#xff0c;主动触发滑块&#xff0c;拿到滑块信息 2.然后滑块验证did 获取captchaToken 3.携带captchaToken访问接口 4.最后校验web端的did 是否激活 最后激活以后的效果如下&#xff1a; 经过测试&…

微服务-服务拆分

文章目录 服务拆分及注意事项服务拆分案例案例代码分析 服务拆分及注意事项 每个服务有独立的数据库&#xff0c;订单模块需要查询用户信息时&#xff0c;通过调用用户模块的接口&#xff0c;自身的数据库并没有用户信息。 服务拆分案例 案例结构 案例有2个微服务&#xff0c;…

【跟小嘉学 Rust 编程】三十三、Rust的Web开发框架之一: Actix-Web的基础

系列文章目录 【跟小嘉学 Rust 编程】一、Rust 编程基础 【跟小嘉学 Rust 编程】二、Rust 包管理工具使用 【跟小嘉学 Rust 编程】三、Rust 的基本程序概念 【跟小嘉学 Rust 编程】四、理解 Rust 的所有权概念 【跟小嘉学 Rust 编程】五、使用结构体关联结构化数据 【跟小嘉学…

基于Kubesphere容器云平台物联网云平台Devops实践

基于Kubesphere容器云平台物联网云平台Devops实践 项目背景 ​ 公司是做工业物联网相关业务的&#xff0c;现业务是云平台&#xff0c;技术栈 后端为 Springboot2.7JDK11 &#xff0c;前端为 Vue3Ts&#xff0c;需要搭建自动化运维平台以实现业务代码自动部署上线&#xff0c;…

【C++笔记】如何用检查TCP或UDP端口是否被占用

一、检查步骤 使用socket函数创建socket_fd套接字。使用sockaddr_in结构体配置协议和端口号。使用bind函数尝试与端口进行绑定&#xff0c;成功返回0表示未被占用&#xff0c;失败返回-1表示已被占用。 二、步骤详解 2.1 socket函数 socket 函数是用于创建套接字的函数&…

【MySql】9- 实践篇(七)

文章目录 1. 一主多从的主备切换1.1 基于位点的主备切换1.2 GTID1.3 基于 GTID 的主备切换1.4 GTID 和在线 DDL 2. 读写分离问题2.1 强制走主库方案2.2 Sleep 方案2.3 判断主备无延迟方案2.4 配合 semi-sync方案2.5 等主库位点方案2.6 GTID 方案 3. 如何判断数据库是否出问题了…

Django 实战开发(一)项目搭建

1.项目搭建 用pycharm 编辑器可以直接 New 一个 Django 项目 2.新建应用 python manage.py startapp demo项目结构如下: 3.编写第一个Django 视图函数 /demo/views: from django.http import HttpResponse def welcome(request):return HttpResponse("welcome to dja…

品牌媒介工作流程是什么,媒体投放目标怎么做?

品牌媒介其实说简单也很简单&#xff0c;说难也很难&#xff0c;简单在于其实事情流程简洁&#xff0c;难呢&#xff0c;在于很多东西如果不亲身体验是无法领悟到精髓的。今天为大家分享下品牌媒介工作流程是什么&#xff0c;媒体投放目标怎么做&#xff1f; 我们怎么才能在媒体…

JWT的封装、[Authorize]的使用

JWT的封装 需要安装两个包。 包1&#xff1a;System.IdentityModel.Tokens.Jwt Install-Package System.IdentityModel.Tokens.Jwt 包2&#xff1a;Microsoft.AspNetCore.Authentication.JwtBearer Install-Package Microsoft.AspNetCore.Authentication.JwtBearer 我们创建一…

【Unity】3D跑酷游戏

展示 finish_all * 方块跑酷 1.教程链接 翻墙&#xff1a;https://www.youtube.com/watch?v9ZEu_I-ido4&listPLPV2KyIb3jR53Jce9hP7G5xC4O9AgnOuL&index3 2.基础制作 最终成果 2.1 基本场景 1.创建Cube作为跑道 1&#xff09;记得把位置Reset&#xff1b; 2&#…

C#使用mysql-connector-net驱动连接mariadb报错

给树莓派用最新的官方OS重刷了一下&#xff0c;并且用apt install mariadb-server装上“mysql”作为我的测试服务器。然后神奇的事情发生了&#xff0c;之前用得好好的程序突然就报错了&#xff0c;经过排查&#xff0c;发现在连接数据库的Open阶段就报错了。写了个最单纯的Con…

CSDN学院 < 华为战略方法论进阶课 > 正式上线!

目录 你将收获 适用人群 课程内容 内容目录 CSDN学院 作者简介 你将收获 提升职场技能提升战略规划的能力实现多元化发展综合能力进阶 适用人群 主要适合公司中高层、创业者、产品经理、咨询顾问&#xff0c;以及致力于改变现状的学员。 课程内容 本期课程主要介绍华为…

【发展史】鼠标的发展史

最早可以追溯到1952年&#xff0c;皇家加拿大海军将5针保龄球放在能够侦测球面转动的硬件上&#xff0c;这个硬件再将信息转化成光标在屏幕上移动&#xff0c;用作军事计算机输入。这是我们能够追溯到的最早的依靠手部运动进行光标移动的输入设备。但当时这个东西不叫鼠标&…

Ps:套索工具

Ps 的套索工具有三种&#xff0c;主要通过手动绘制的方式创建选区。 套索工具 Lasso Tool 又称“自由套索工具”&#xff0c;可绘制任意形状的选区&#xff0c;灵活快速但不够精确&#xff0c;是仅需粗略选区时&#xff08;比如&#xff0c;生成式填充等&#xff09;最常用的工…

XTU-OJ 1178-Rectangle

题目描述 给你两个平行于坐标轴的矩形&#xff0c;请判断两者是不是相交&#xff08;面积有重合的部分&#xff09;&#xff1f; 输入 第一行是一个整数K&#xff0c;表示样例数。 每个样例占两行&#xff0c;每行是4个整数&#xff0c;表示一个矩形的对角线点的坐标&#xff0…

【API篇】十一、Flink水位线传递与迟到数据处理

文章目录 1、水位线传递2、水位线设置空闲等待3、迟到数据处理&#xff1a;窗口允许迟到4、迟到数据处理&#xff1a;侧流输出5、问 1、水位线传递 上游task处理完水位线&#xff0c;时钟改变后&#xff0c;要把数据和当前水位线继续往下游算子的task发送。当一个任务接收到多…

对mysql的联合索引的深刻理解

背景 对mysql的联合索引的考察是Java程序员面试高频考点&#xff01;必须深刻理解掌握否则容易丢分非常可惜。 技术难点 考察对最左侧匹配原理理解。 原理 暂且不表。网上讲这非常多。我理解就是&#xff0c;B树每个非叶子节点的值都是有序存放索引的值。 比如对A、B、C …

unity 基于UGUI的无限动态滚动列表

基于UGUI的动态滚动列表&#xff0c;主要支持以下功能&#xff1a; 继承自UGUI的SrollRect&#xff0c;支持ScrollRect的所有功能&#xff1b; 使用对象池来管理列表元素&#xff0c;以实现列表元素的复用&#xff1b; 支持一行多个元素或一列多个元素&#xff1b; 可使用不…

漏洞复现--用友 畅捷通T+ .net反序列化RCE

免责声明&#xff1a; 文章中涉及的漏洞均已修复&#xff0c;敏感信息均已做打码处理&#xff0c;文章仅做经验分享用途&#xff0c;切勿当真&#xff0c;未授权的攻击属于非法行为&#xff01;文章中敏感信息均已做多层打马处理。传播、利用本文章所提供的信息而造成的任何直…