C语言-不对称边界实现二分法查找

2024-05-01 13:18

本文主要是介绍C语言-不对称边界实现二分法查找,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C 语言-不对称边界实现二分法查找

问题描述

对一个已经排序的整数表执行二分查找。函数的输入包括一个指向表头的指针,表中的元素,以及待查找的数值,函数的输出是一个指向满足查找要求的元素的指针,当未查找到要求的数值时,输出一个 NULL 指针。

不对称边界

用第一个如界点和第一个出界点来表示一个数值范围

实现

方法一

int bsearch(int *t, int n, int x)
{int lo;int hi;int mid;lo = 0; /* 第一个入界点*/hi = n; /* 第一个出界点 */while(lo < hi){mid = (lo + hi) /  2;if(x < t[mid])hi = mid;                      /* 第一个出界点*/else if(x > t[mid])lo = mid + 1;                  /* 第一个入界点 */elseretuan t + mid;                /* 找到了 */}return NULL;                           /* 没找到 */
}

在很多机器上下标运算比指针运算慢。我们可以把, t + mid 的存储在一个局部变量中,这样就不需要每次都计算,从而可以稍微减少一些内存

int bsearch(int *t, int n, int x)
{int lo;int hi;int mid;int * p;lo = 0; /* 第一个入界点*/hi = n; /* 第一个出界点 */while(lo < hi){mid = (lo + hi) /  2;p = t + mid;if(x < *p)hi = mid;                      /* 第一个出界点*/else if(x > *p)lo = mid + 1;                  /* 第一个入界点 */elseretuan p;                      /* 找到了 */}return NULL;                           /* 没找到 */
}

进一步减少寻址计算,这可以在整个程序中使用指针代表下标,

int bsearch(int *t, int n, int x)
{int *lo;int *hi;int *mid;lo = t;      /* 第一个入界点*/hi = t + n;  /* 第一个出界点 */while(lo < hi){mid = (lo + hi) /  2;if(x < *mid)hi = mid;                      /* 第一个出界点*/else if(x > *mid)lo = mid + 1;                  /* 第一个入界点 */elseretuan mid;                    /* 找到了 */}return NULL;                           /* 没找到 */
}

仔细思考一下

mid = (lo + hi) / 2

指针加指针这个是非法的!!!!!

mid = lo + (hi - lo) / 2

将除法运算转换为移位运算

mid = lo + (hi - lo) >> 2;

感觉优化完了,,,

算术运算符的优先级大于移位运算符!!!!!

mid = lo + ((hi - lo) >> 2)

所以最终的表达式为

int bsearch(int *t, int n, int x)
{int *lo;int *hi;int *mid;lo = t;      /* 第一个入界点*/hi = t + n;  /* 第一个出界点 */while(lo < hi){mid = lo + ((hi - lo) >> 1);if(x < *mid)hi = mid;                      /* 第一个出界点*/else if(x > *mid)lo = mid + 1;                  /* 第一个入界点 */elseretuan mid;                    /* 找到了 */}return NULL;                           /* 没找到 */
}

这篇关于C语言-不对称边界实现二分法查找的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/951792

相关文章

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

Python xmltodict实现简化XML数据处理

《Pythonxmltodict实现简化XML数据处理》Python社区为提供了xmltodict库,它专为简化XML与Python数据结构的转换而设计,本文主要来为大家介绍一下如何使用xmltod... 目录一、引言二、XMLtodict介绍设计理念适用场景三、功能参数与属性1、parse函数2、unpa

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

C# 读写ini文件操作实现

《C#读写ini文件操作实现》本文主要介绍了C#读写ini文件操作实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、INI文件结构二、读取INI文件中的数据在C#应用程序中,常将INI文件作为配置文件,用于存储应用程序的