news 2026/6/10 11:49:59

对上篇二分查找的纠正和补充

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
对上篇二分查找的纠正和补充

1.上篇提到无序数组用sort排序再二分,感觉被自己蠢笑了,因为sort函数的时间复杂度O(nlogn),二分查找是(logn),所以这个是无意义的。然后上一篇sort函数用法也写错了,应该是sort(a+1, a + n+1),因为初始下标为1,注意一下就行

2.然后这里补充一下有一个极值时怎么用二分查找,假如有7个数字:1 2 3 4 3 2 1,我们想要用二分找峰值,但是它不是一个有序的数列,所以我们可以做一下变形,我们先假定一个函数y=x^2,我们对它求导后,当y`=0时,x=0,也就是说此时取得极值,也是峰值,咋们再回到我们这个数列,也可以把它看作一个函数,其中每2个相邻的数的dx=每个相邻数下标差为1,dy=arr[i]-arr[i-1],dy/dx就是此时的导数值,也可以叫变化率

那么我们此时得到一个新的数组 1 1 1 -1 -1 -1,这里就是一个从正到负的有序数组了,我们定义两个变量 int cur,pre,所以就有当前数-前一个数<0时,假设此时mid=5,那么就是说arr[5]-arr[4]<0时,找到峰值下标mid-1。以下是代码实现:

#include<iostream> #include<algorithm> using namespace std; int istop(int cur, int pre) { return cur - pre <0 ;//当前数字减去前一个数字 } int main() { int n=7;//n为数组长度 int a[100];//存储输入元素 int ans = -1; //初始化目标值下标 for (int i = 1; i <= n; i++) { //用for循环输入每一个元素 cin >> a[i]; } int l = 1, r =7;//l是数组左端点,r是右端点 while (l <= r) { //当l>r时,说明此时已经找到目标元素或者没有目标元素 int mid = (l + r) / 2; //中间点下标 if (istop(a[mid],a[mid-1])) { ans = mid-1; r = mid - 1;//继续向左找更早的位置,此时数字可能重复; } else { l = mid + 1; //向右继续查找 } } if (ans == -1) { cout << "元素x不在数组中" << endl; } else { cout << ans << endl; } return 0; }

3.如果是找极小值:把return cur - pre <0改为return cur - pre >0,原理是一样的

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 15:47:58

中文论文格式模板下载指南:让学术写作更轻松 ✨

中文论文格式模板下载指南&#xff1a;让学术写作更轻松 ✨ 【免费下载链接】中文论文格式模板下载分享 中文论文格式模板下载 项目地址: https://gitcode.com/Open-source-documentation-tutorial/90604 还在为论文格式发愁吗&#xff1f;别担心&#xff01;我们为您精…

作者头像 李华
网站建设 2026/6/9 18:07:23

YubiKey SSH认证终极指南:从零开始实现无密码安全登录

YubiKey SSH认证终极指南&#xff1a;从零开始实现无密码安全登录 【免费下载链接】YubiKey-Guide Guide to using YubiKey for GPG and SSH 项目地址: https://gitcode.com/gh_mirrors/yu/YubiKey-Guide 在当今网络安全威胁日益严峻的环境下&#xff0c;传统的密码认证…

作者头像 李华
网站建设 2026/6/10 15:07:51

孤能子视角:“DeepSeek偏向中文思考“本质推测

(留待以后验证)我的问题:1.用英文翻译"创新推动发展"。2.果然&#xff0c;英文思维更具实体化&#xff0c;中文动词亦可是名词&#xff0c;可以静态也可以动态理解。3.西方发现使用DeepSeek时思考过程出现中文。而DeepSeeK是关系思维模式。现在看来&#xff0c;很有道…

作者头像 李华
网站建设 2026/6/10 15:49:13

MCP安全认证终极指南:如何在7天内从零到部署的完整实战

MCP安全认证终极指南&#xff1a;如何在7天内从零到部署的完整实战 【免费下载链接】mcp-for-beginners This open-source curriculum is designed to teach the concepts and fundamentals of the Model Context Protocol (MCP), with practical examples in .NET, Java, and …

作者头像 李华
网站建设 2026/6/10 17:04:31

容器与迭代器

迭代器迭代器按照定义方式分成以下四种&#xff1a;1.正向迭代器(最常用)&#xff0c;定义方法如下&#xff1a;容器类名::iterator 迭代器名; map<int, double>::iterator itor;2.常量正向迭代器&#xff0c;定义方法如下&#xff1a;容器类名::const_iterator 迭代器名…

作者头像 李华
网站建设 2026/6/10 11:52:46

Champ项目实战指南:AI驱动的人体动画生成技术深度解析

你知道吗&#xff1f;传统的人体动画生成往往面临动作不自然、细节丢失的难题&#xff0c;而Champ项目通过创新的3D参数化引导技术&#xff0c;让AI能够生成既可控又连贯的人体动画效果。想象一下&#xff0c;只需一张参考图片和简单的姿态序列&#xff0c;就能让静态人物"…

作者头像 李华