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

备战蓝桥杯:二分算法之牛可乐和魔法封印问题

这道题就是一道简单的模板题,我们分析一下!,首先我们要找大于等于x的起始位置

我们还是用两个指针,left指向1,right指向n,如果a[mid]<x  left = mid+1

如果a[mid]>=x 就让right= mid

如果数组全是小于x的话,x = 3 ,[0 , 1 , 2]   我们最后就会指向2,2还是小于x的,所以我们这个数组大于等于x的值不存在,返回0

接下来我们找一下小于等于y的终止位置

如果a[mid]大于y,right=mid-1,

如果a[mid]小于等于y,left=mid+1

我们还需要考虑一下最后结果可能是大于y的情况,比如y是3,数组是[4,5,6]的话,结果是4,4还是大于3的,根本就找不到小于等于3的区间,所以返回0

好的,话不多说我们写一下代码

#include <iostream>
using namespace std;
const int N = 1e5 + 10;
int n;
int a[N];
int binary_search(int x1, int x2)
{int left = 1, right = n;while (left < right){int mid = (left + right) / 2;if (a[mid] >= x1) right = mid;else left = mid + 1;}if (a[left] < x1) return 0;int tmp = left;left = 1, right = n;while (left < right){int mid = (left + right + 1) / 2;if (a[mid] <= x2) left = mid;else right = mid - 1;}if(a[left]>x2) return 0;return left - tmp + 1;
}
int x, y;
int main()
{cin >> n;for (int i = 1; i <= n; i++) cin >> a[i];int q; cin >> q;while (q--){cin >> x >> y;cout << binary_search(x, y) << endl;}
}

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

相关文章:

  • 普通用户授权docker使用权限
  • 【实战篇】DeepSeek + ElevenLabs:让人工智能“开口说话”,打造你的专属语音助手!
  • Vision Transformer:打破CNN垄断,全局注意力机制重塑计算机视觉范式
  • LabVIEW国内外开发的区别
  • 【并发控制、更新、版本控制】.NET开源ORM框架 SqlSugar 系列
  • 淘宝App交易链路终端混合场景体验探索
  • 数据中心网络监控
  • 【含开题报告+文档+PPT+源码】基于springboot的汽车销售管理系统的设计与实现
  • flink cdc2.2.1同步postgresql表
  • rebase和merge
  • Spring boot中实现字典管理
  • 调用DeepSeek官方的API接口
  • 3.3 学习UVM中的uvm_driver 类分为几步?
  • Python——批量图片转PDF(GUI版本)
  • 科技查新过不了怎么办
  • WPS中如何批量上下居中对齐word表格中的所有文字
  • 【Docker】从瀑布开发到敏捷开发
  • 若依框架二次开发——若依介绍、环境部署及更换项目包路径
  • 【DeepSeek】在本地计算机上部署DeepSeek-R1大模型实战(完整版)
  • 996引擎-问题处理:三职业改单职业
  • Redis 发生宕机时,数据怎样恢复?
  • 【02】RUST项目(Cargo)
  • 二、通义灵码插件保姆级教学-IDEA(使用篇)
  • Docker使用指南与Dockerfile文件详解:从入门到实战
  • 前端权限控制和管理
  • 网络安全讲座之一:网络安全的重要性
  • iOS主要知识点梳理回顾-3-运行时消息机制
  • 深度学习中的Checkpoint是什么?
  • STM32开发笔记,编译与烧录
  • 【CXX-Qt】1 CXX-Qt入门