当前位置: 首页 > news >正文

手搓二分查找

第一种:

该种方法是若a[mid]==目标数,则让r一直等于mid,让l往右移动,一直移动到r=l,这时候跳出循环,在循环外判断
但是不能写成让l=mid,让r往左移动,比如a[2]==key,这时,mid=2,若l一直等于2,r移动到3,mid=(2+3)/2=2会一直执行while循环,跳不出来
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
bool binary1(int a[],int key,int len)
{	//该种方法是若a[mid]==目标数,则让r一直等于mid,让l往右移动,一直移动到r=l,这时候跳出循环,在循环外判断
//但是不能写成让l=mid,让r往左移动,比如a[2]==key,这时,mid=2,若l一直等于2,r移动到3,mid=(2+3)/2=2会一直执行while循环,跳不出来int l = 0;int r = len-1;while (l<r){int mid = l + r >>1;		//左移1位,相当于(l+r)/2if (key <= a[mid])	r = mid;else l = mid + 1;}if (a[r] == key)	return true;return	false;}int main()
{int a[7] = { 12,4,57,87,32,1,23 };sort(a, a + 7, less<int>());    //二分查找前必须先排序,且必须是升序if (binary1(a, 12, sizeof(a) / sizeof(int)))cout << "yes\n";else cout << "no\n";return 0;
}

第二种:   

该方法是在while循环中判断a[mid]是否等于key,若找到则返回true,若最后一次循环即l==r,这时a[mid]≠key,则跳出循环,返回false

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;bool binary2(int a[], int key,int len)
{	//该方法是在while循环中判断a[mid]是否等于key,若找到则返回true,若最后一次循环即l==r,这时a[mid]≠key,则跳出循环,返回falseint l = 0;int r = len - 1;while (l <= r){int mid = l + r >> 1;if (key == a[mid])	return true;else if (key > a[mid])	l = mid + 1;else r = mid - 1;}return false;
}
int main()
{int a[7] = { 12,4,57,87,32,1,23 };sort(a, a + 7, less<int>());	//二分查找前必须先排序,且必须是升序if (binary2(a, 13, sizeof(a) / sizeof(int)))cout << "yes" << endl;else cout << "no" << endl;return 0;
}

http://www.lryc.cn/news/331674.html

相关文章:

  • pycharm调试(步过(Step Over)、单步执行(Step Into)、步入(Step Into)、步出(Step Out))
  • Linux是什么,该如何学习
  • C++ | Leetcode C++题解之第7题整数反转
  • Linux------一篇博客了解Linux最常用的指令
  • vscode安装通义灵码
  • RIP协议(路由信息协议)
  • SpringBoot根据配置类动态加载不同环境下的自定义配置
  • 什么?穷哥们没钱RLHF?跟我一起DPO吧,丐版一样用
  • 【Leetcode笔记】102.二叉树的层序遍历
  • 进程的状态
  • spring-boot集成websocket
  • 【Python】【Flask】提交表单后报500错误
  • Golang vs Java
  • HomePlug AV
  • 【面试八股总结】超文本传输协议HTTP(二)
  • SQL Server中视图使用子查询的性能影响与优化方案
  • Adaboost集成学习 | Matlab实现基于SVM-Adaboost支持向量机结合Adaboost集成学习时间序列预测(股票价格预测)
  • Apache DolphinScheduler 【安装部署】
  • 【随笔】Git -- 高级命令(上篇)(六)
  • java中Date类,SimpleDateFormat类和Calendar类
  • 施耐德 PLC 控制系统 产品 + 软件总体介绍 2020
  • UniApp 应用发布到苹果商店指南
  • KamaCoder 46. 携带研究材料(第六期模拟笔试)
  • MySQL的基本操作(超详细)
  • 自动驾驶之心规划控制笔记
  • Linux中部署Java jar 包 shell 脚本
  • auto.js v1.4.4 实现自动打卡
  • 【Linux实验室】NFS、DHCP的搭建
  • Samba 总是需要输入网络凭证
  • 图像处理_积分图