c++ 元二分搜索 | 单边二分查找(Meta Binary Search | One-Sided Binary Search)

        元二分搜索(Steven Skiena 在《算法设计手册》第 134 页中也称为单边二分搜索)是二分搜索的一种修改形式,它以增量方式构建数组中目标值的索引。与普通二分搜索一样,元二分搜索需要 O(log n) 时间。

        元二分搜索,也称为单边二分搜索,是二分搜索算法的一种变体,用于搜索有序列表或元素数组。该算法旨在减少在列表中搜索给定元素所需的比较次数。

        元二分搜索背后的基本思想是从包含整个数组的大小为 n 的初始区间开始。然后,该算法像二分搜索一样计算中间元素,并将其与目标元素进行比较。如果找到目标元素,则搜索终止。如果中间元素大于目标元素,则算法将新区间设置为前一个区间的左半部分,如果中间元素小于目标元素,则将新区间设置为前一个区间的右半部分间隔。但是,与二分搜索不同,元二分搜索不会对循环的每次迭代执行比较。

        相反,该算法使用启发式方法来确定下一个间隔的大小。它计算中间元素的值与目标元素的值之间的差值,并将差值除以预定常数(通常为2)。然后将该结果用作新区间的大小。该算法将继续进行,直到找到目标元素或确定它不在列表中。

        元二分搜索相对于二分搜索的优势在于,它在某些情况下可以执行更少的比较,特别是当目标元素接近列表开头时。缺点是在其他情况下,该算法可能比二分查找执行更多的比较,特别是当目标元素接近列表末尾时。因此,当列表的排序方式与目标元素的分布一致时,元二分搜索是最有效的。
 

这是元二分搜索的伪代码:
function meta_binary_search(A, target):
    n = length(A)
    interval_size = n
    while interval_size > 0:
        index = min(n - 1, interval_size / 2)
        mid = A[index]
        if mid == target:
            return index
        elif mid < target:
            interval_size = (n - index) / 2
        else:
            interval_size = index / 2
    return -1

例子:
Input: [-10, -5, 4, 6, 8, 10, 11], key_to_search = 10
Output: 5

Input: [-2, 10, 100, 250, 32315], key_to_search = -2
Output: 0 

确切的实现有所不同,但基本算法有两个部分:  
        1、计算出存储最大数组索引需要多少位。
        2、通过确定索引中的每个位应设置为 1 还是 0,增量构造数组中目标值的索引。
方法:
        1、在变量 lg 中存储表示最大数组索引的位数。
        2、使用 lg 在 for 循环中开始搜索。
        3、如果找到该元素,则返回 pos。
        4、否则,在 for 循环中增量构造索引以达到目标值。
        5、如果找到元素,则返回 pos,否则返回 -1。
下面是上述方法的实现: 

// C++ implementation of above approach
 
#include <iostream>
#include <cmath>
#include <vector>
using namespace std;
 
// Function to show the working of Meta binary search
int bsearch(vector<int> A, int key_to_search)
{
    int n = (int)A.size();
    // Set number of bits to represent largest array index
    int lg = log2(n-1)+1; 
 
    //while ((1 << lg) < n - 1)
        //lg += 1;
 
    int pos = 0;
    for (int i = lg ; i >= 0; i--) {
        if (A[pos] == key_to_search)
            return pos;
 
        // Incrementally construct the
        // index of the target value
        int new_pos = pos | (1 << i);
 
        // find the element in one
        // direction and update position
        if ((new_pos < n) && (A[new_pos] <= key_to_search))
            pos = new_pos;
    }
 
    // if element found return pos otherwise -1
    return ((A[pos] == key_to_search) ? pos : -1);
}
 
// Driver code
int main(void)
{
 
    vector<int> A = { -2, 10, 100, 250, 32315 };
    cout << bsearch(A, 10) << endl;
 
    return 0;
}
 
// This implementation was improved by Tanin 

输出: 
1

时间复杂度: O(log n),其中 n 是给定数组的大小
辅助空间: O(1) ,因为我们没有使用任何额外空间

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

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

相关文章

Spring Data访问Elasticsearch----实体回调Entity Callbacks

Spring Data访问Elasticsearch----实体回调Entity Callbacks 一、实现实体回调二、注册实体回调三、存储特定的EntityCallbacks Spring Data基础结构提供了钩子&#xff0c;用于在调用某些方法之前和之后修改实体。这些所谓的EntityCallback实例提供了一种方便的方式来检查并可…

适用于 Windows电脑的 iPad 数据恢复软件

如何在 Windows 11/10/8/7 上从 iPad 恢复丢失的数据&#xff1f;其实很简单。您只需在 Windows 11/10/8/7 上下载并安装 iPad 数据恢复软件。然后您可以运行该软件扫描您的 iPad 并查找已删除/丢失的数据。iPad 中的 iOS 数据&#xff08;包括消息、聊天记录、联系人、照片和视…

类和对象 java 要点总结

# 类和对象 - 成员变量 有默认值0 - 成员方法 - 类名&#xff1a;大驼峰 - rename refactor 改类名 - new 实例化对象 - this 当前对象的引用 - this共有2种使用方式&#xff1a; - this.data 访问当前对象的实例成员变量 - this.func() 访问当前对象的实例成员方法 - t…

Vue学习日记 Day7 —— json-server工具、基于VueCli自定义创建项目、postcss插件

一、前一天Vuex总结 1、state作用&#xff1a;存放数据定义&#xff1a;state:{//数据 }使用&#xff1a;//放在data下(1)根节点直接访问this.$store.state.数据名(2)模块直接访问this.$store.state.模块名.数据名(3)根节点辅助函数mapState([所需要的数据])(4)模块辅助…

CTF题型 SSTI(1) Flask-SSTI-labs 通关 题记

CTF题型 SSTI(1) Flask-SSTI-labs 通关 题记 文章目录 CTF题型 SSTI(1) Flask-SSTI-labs 通关 题记前记获取键值或下标的方式获取属性的方式 Level 1 no wafLevel 2 bl[\{\{]Level 3 no waf and blindLevel 4 bl[[, ]]获取键值或下标 Level 5 bl[\, "]Level 6 bl[_]Level …

Java安全基础 必备概念理解

Java安全基础 关键概念汇总 文章目录 Java安全基础 关键概念汇总前置知识1.构造器this以及包的使用2.继承3.重写/ 重载 / super4.多态5.区分和equals方法6.toString的使用7.Object的概念8.static,final,代码块static代码块final 9.动态代理10.类的动态加载1)类加载器含义&#…

【教程】APP加固的那些小事情

摘要 APP加固是保护APP代码逻辑的重要手段&#xff0c;通过隐藏、混淆、加密等操作提高软件的逆向成本&#xff0c;降低被破解的几率&#xff0c;保障开发者和用户利益。本文将介绍APP加固常见失败原因及解决方法&#xff0c;以及处理安装出现问题的情况和资源文件加固策略选择…

【InternLM 笔记】OpenXLAB浦源的基本操作

OpenXLab网址 网址&#xff1a;OpenXLab浦源 模型 创建模型 页面右上角选择【创建】然后选择【创建模型】 创建模型的页面如下 感觉页面中的提示信息填写相应的内容&#xff0c;全部填完后点页面下方的【立即创建】完成模型的创建 模型上传 安装所需的工具 apt install …

目标检测——玉米叶感染数据集

一、重要性 首先&#xff0c;玉米作为世界上重要的粮食作物之一&#xff0c;其生长状况直接影响到粮食产量和粮食安全。玉米叶感染是玉米生长过程中常见的病害之一&#xff0c;会导致玉米叶片出现肿胀、皱缩、扭曲变形等症状&#xff0c;严重时甚至可能形成瘤状物。因此&#…

MySQL特殊函数

MySQL提供了一系列特殊函数&#xff0c;用于执行各种操作&#xff0c;包括数学运算、字符串处理、日期和时间计算等。下面是一些常用的MySQL特殊函数及其样例&#xff1a; 1. **数学函数**&#xff1a; - ABS(x)&#xff1a;返回x的绝对值。 - 样例&#xff1a;SELECT AB…

plsql如何添加索引?

索引是对表中一列或多列的值进行排序的一种结构&#xff0c;使用索引可快速访问数据库表中的特定信息。如果想按特定职员的姓来查找他或她&#xff0c;则与在表中搜索所有的行相比&#xff0c;索引有助于更快地获取信息。索引的一个主要目的就是加快检索表中数据的方法&#xf…

【LIMS】微服务

目录 一、服务解决方案-Spring Cloud Alibaba1.1选用原因&#xff08;基于Spring Cloud Alibaba的试用场景&#xff09;1.2 核心组件使用前期规划 部署 nacos部署 mino使用JavaFreemarker模板引擎&#xff0c;根据XML模板文件生成Word文档使用JavaFlowable 工作流引擎前端 -vue…

Python实现视频转音频、音频转文本加文本实体识别

文章目录 概述必备第三方库视频转音频音频转文字完整代码命名实体识别NER注意点概述 本教程希望可以识别出目前活跃的视频平台(例如抖音、快手等)中视频文案中蕴含的实体信息,首先有两条技术路径: 直接提取视频帧,之后实现逐帧的字幕识别,最后合并为视频文案。 优点:准…

为什么Python语言那么受欢迎呢?

Python语言受到广泛欢迎的原因有很多。首先&#xff0c;让我们来了解一下Python语言的背景和历史。Python是由Guido van Rossum在上世纪90年代初开发的一种高级编程语言。自从他在1989年发布第一个Python解释器以来&#xff0c;Python一直在不断发展和完善。其简洁、易读的语法…

js获取年月日

const date new Date()const options { year: numeric, month: 2-digit, day: 2-digit }const dateString date.toLocaleDateString(zh-CN, options)const [year, month, day] dateString.split(/)console.log(year, month, day) 人工智能学习网站&#xff1a; https://ch…

C++ 中的 Pimpl 惯用法

Pimpl 是一种常见的 C 设计模式&#xff0c;用于隐藏类的实现细节&#xff0c;从而减少编译依赖和提高编译速度。本文将通过一个较为复杂的例子&#xff0c;展示如何使用智能指针&#xff08;如 std::unique_ptr&#xff09;来实现 Pimpl 惯用法。 参考: Pimpl 用法

ArcGIS Pro 和 ArcMap 10个不同

ArcGIS Pro 和 ArcMap 都是 ESRI 开发的地理信息系统 (GIS) 软件,但它们在设计、功能和用户体验方面有一些显著的区别。以下是 ArcGIS Pro 和 ArcMap 之间的 10 个主要不同点: 界面和用户体验: ArcGIS Pro 采用了现代化的、基于Ribbon的界面,与 Microsoft Office 应用程序相…

在 Mac 上通过“启动转换助理”安装 Windows 10

在 Mac 上通过“启动转换助理”安装 Windows 10 你可以通过“启动转换”在 Mac 上安装 Microsoft Windows 10&#xff0c;然后在重新启动 Mac 时在 macOS 和 Windows 之间进行切换。 在 Mac 上安装 Windows 10 需要满足的条件 只有在搭载 Intel 处理器的 Mac 上才能使用“启…

Kubernetes 项目整体布局 el-container

整体布局整体布局 你可能会去敲不同的项目&#xff0c;有很多种平台。那么其实都是可以复用的。唯一不同的就是main里面的内容是不同的&#xff0c;边框架子都是相同的。其实框架是不怎么变化的&#xff0c;变化的是main里面。 src/layout/Layout.vue 这里需要新增一个页面Lay…

高效求解!图片转换方法大揭秘,清晰度零损失!

在数字时代&#xff0c;图片转换是我们处理和共享图像时经常面临的任务之一。随着不同平台、应用程序和需求的不断增多&#xff0c;高效的图片转换方法变得至关重要。本文将为您揭秘一系列高效的图片转换方法&#xff0c;确保在转换过程中清晰度零损失。 无论是为了适应不同的…