【数据结构与算法】整数二分
问题描述
对一个排好序的数组,要求找到大于等于7的最小位置和小于等于7的最大位置

大于等于7的最小位置
易知从某个点开始到最右边的边界都满足条件,我们要找到这个区域的最左边的点。

开始二分!
left指针指向最左边界,right指针指向最右边界。
mid = (left + right )/2,指向6
if(check(x[mid]>=7)) right = mid
else left = mid +1
这里6<7,mid指向的元素不符合条件,left 右移至mid + 1
重新计算mid,mid指向9
9>7,满足条件,right 移到mid处,
重新计算mid,mid指向8
8>7,满足条件,right 移到mid处
mid = 8, left = right 停止!
小于等于7的最大位置
易知从左边界到某个点都满足条件,我们要找到这个区域的最右边的点。

eft指针指向最左边界,right指针指向最右边界。
mid = (left + right +1 )/2,指向6
if(check(x[mid]<=7)) left= mid
else right = mid -1
代码
acwing 789 找整数出现的初次和最后一次
#include <iostream>using namespace std;int mat[100001];//找满足条件的最左边界
void findlx(int mat[], int quei, int n){int left = 0;int right = n-1;int mid;while(left!=right){mid = (left +right )>>1;if(mat[mid] >= quei){right = mid;}else {left = mid + 1;}}if(mat[left]!=quei){cout<<-1<<" ";}else{cout<<left<<" ";}}//找满足条件最右边界
void findrx(int mat[], int quei, int n){int left = 0;int right = n-1;int mid;while(left!=right){mid = (right + left +1)>>1;if(mat[mid]<=quei){left = mid;}else{right = mid -1 ;}}if(mat[left]!=quei){cout<<-1<<endl;}else{cout<<left<<endl;}}int main(){int n,q;cin>>n>>q;int i;for(i =0 ; i< n; i++){cin>>mat[i];}for(i =0; i<q; i++){int quei;cin>>quei;int start, end;findlx(mat, quei, n);findrx(mat, quei, n);}return 0;}
相关文章:
【数据结构与算法】整数二分
问题描述 对一个排好序的数组,要求找到大于等于7的最小位置和小于等于7的最大位置 大于等于7的最小位置 易知从某个点开始到最右边的边界都满足条件,我们要找到这个区域的最左边的点。 开始二分! left指针指向最左边界,right…...
java项目打包运行报异常:xxxxx-1.0-SNAPSHOT.jar中没有主清单属性
pom.xml中加入这段话即可 <build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>2.4.4</version><executions><execution><…...
MAC-键盘command快捷键、设置windows快捷键
在 Windows PC 专用键盘上,请用 Alt 键代替 Option 键,用 Ctrl 键或 Windows 标志键代替 Command 键。 Mac 键盘快捷键 - 官方 Apple 支持 (中国) 设置windows快捷键 使用mac外接适用于windows的键盘时,如何设置快捷键?_mac外…...
C++ 补充之常用遍历算法
C遍历算法和原理 C标准库提供了丰富的遍历算法,涵盖了各种不同的功能。以下是一些常见的C遍历算法以及它们的概念和原理的简要讲解: for_each:对容器中的每个元素应用指定的函数。 概念:对于给定的容器和一个可调用对象ÿ…...
【Linux杂货铺】调试工具gdb的使用
目录 🌈前言🌈 📁背景介绍 📁 使用 list [行号] / [函数名] run/r break/b [行号] / [函数名] info break disable break enable break delete break [断点编号] next/n step/s continue/c finish print/p [变量…...
FL Studio Producer Edition2024中文进阶版Win/Mac
FL Studio Producer Edition,特别是其【中文进阶版 Win/Mac】,是数字音乐制作领域中的一款知名软件。它为广大音乐制作人、声音工程师以及音乐爱好者提供了一个从音乐构思到最终作品发布的完整解决方案。这个版本特别为中文用户优化,并兼容W…...
无需邀请码,Xinstall实现精准分享归因
在如今的移动互联网时代,分享已经成为了我们日常生活中不可或缺的一部分。无论是社交媒体上的好友分享,还是应用内的内容分享,分享都能够帮助我们快速传播信息,扩大影响力。然而,对于开发者而言,分享却带来…...
机器人与AGI会撞出什么火花?
真正的科技变革是不是就要来临了?各方大佬都开始布局机器人,对于普通人的就业会造成什么影响? 优牛企讯-企业动态信息监控专家 在优牛企讯-企业动态监控专家搜索可知,全国目前的机器人公司已经达到了26401家,近一年…...
Linux yum安装pgsql出现Bad GPG signature错误
官方文档:https://www.postgresql.org/download/linux/redhat/ sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm sudo yum install -y postgresql12-server sudo /usr/pgsql-12/bin/…...
第18章-DHCP
1. 产生背景 2. 概述 2.1 定义 2.2 特点 2.3 DHCP系统组成 3. DHCP工作原理 3.1 前提条件 3.2 场景 3.3 分配IP地址工作机制 3.4 特殊情况处理 3.5 IP地址租约更新 4. DHCP中继代理 4.1 现实场景 4.2 工作机制 1. 产生背景 现实问题: 小型网络中&…...
[物联网] OneNet 多协议TCP透传
[物联网] OneNet 多协议TCP透传 STM32物联网–ONENET云平台的多协议接入产品创建 : https://blog.csdn.net/qq_44942724/article/details/134492924 Onenet tcp 透传 : https://blog.csdn.net/flyme2010/article/details/107086001 tcp服务端测试工具 : http://tcp.xnkiot.com/…...
如何让网页APP化 渐进式Web应用(PWA)
前言 大家上网应该发现有的网页说可以安装对应应用,结果这个应用好像就是个web,不像是应用,因为这里采用了PWA相关技术。 PWA,全称为渐进式Web应用(Progressive Web Apps),是一种可以提供类似…...
50 vmalloc 的实现
前言 这里说的是 内核中分配按页分配的场景 常用于 驱动什么的, 分配 中大型空间 由于 连续的 n 个页是分别使用 alloc_pages 分配的, 因此是 虚拟地址空间连续, 但是 物理地址空间不连续 如何分配对象 两个步骤, __get_vm_area_node 获取为 size 分配的 vma 区间, 然后…...
程序员的金三银四求职宝典!
目录 编辑 程序员的金三银四求职宝典 一、为什么金三银四是程序员求职的黄金时期? 二、如何准备金三银四求职? 1. 完善简历 2. 增强技术能力 3. 提前考虑目标公司 4. 提前准备面试 三、程序员求职的常见面试题 1. 数据结构和算法 2. 数据库 …...
day04_拦截器Apifox角色管理(登录校验,API接口文档,权限管理说明,角色管理,添加角色,修改角色,删除角色)
文章目录 1. 登录校验1.1 需求说明1.2 实现思路1.3 ThreadLocal1.4 AuthContextUtil1.5 拦截器使用1.5.1 拦截器开发1.5.2 拦截器注册 1.6 代码优化1.6.1 配置优化1.6.2 代码优化1.6.3 前端修改 2. API接口文档2.1 Apifox接口管理平台2.1.1 接口管理平台简介2.1.2 Apifox简介2.…...
在线上传解压PHP文件代码,压缩/压缩(网站一键打包)支持密码登录
在线上传解压PHP文件代码,压缩/压缩(网站一键打包)支持密码登录 资源宝分享:www.httple.net 如果你没有主机控制面板这个是最好选择,不需要数据库,上传当控制面板使用,无需安装任何扩展,安全高,…...
【刷题】模拟
模拟算法:题目中已经告诉应该怎么做了,只需要模拟即可,思路比较简单,比较考察代码能力。 一般先在草稿纸上模拟流程,如果直接写代码,容易忽视细节,并且不容器调试! 优化策略&#…...
【打工日常】使用docker部署在线Photopea用于linux下替代ps
一、Photopea介绍 linux没有ps适配,对于有时候工作来说确实不方便,我找了很久,才找到了一款功能可以跟ps接近的在线软件,使用docker部署就可以了。它是ps的最佳替代品之一,其界面几乎与ps相同,只不过它是在…...
leetcode 热题 100_盛最多水的容器
题解一: 双指针遍历:容量计算公式为min(左高度,右高度)*底部距离,我们可以令底部距离逐步递减(左右两边的指针向中部移动)。此时对于min(左高度,右高度),假设较高的线向中部移动&…...
基本正则表达式
基本正则表达式 正则命令功能^尖角号,用于模式的最左侧,如“^oldbpy",匹配以oldboy单词开头的行$美元符,用于模式的最右侧,如"oldboy$",表示以oldboy单词结尾的行^$组合符&…...
Cogito 3B效果展示:128K上下文内跨章节引用——技术白皮书重点定位实测
Cogito 3B效果展示:128K上下文内跨章节引用——技术白皮书重点定位实测 1. 引言:当模型能“记住”一整本书 想象一下,你拿到一份长达数百页的技术白皮书,里面包含了产品介绍、技术架构、性能参数、应用案例等十几个章节。你需要…...
RAG 还是 Lucene:私有化部署客服系统的 AI 知识库架构选型娜
在之前的文章中,我们花了大量的篇幅,从记录后端pod真实ip开始说起,然后引入envoy,再解决了各种各样的需求:配置自动重载、流量劫持、sidecar自动注入,到envoy的各种能力:熔断、流控、分流、透明…...
Jira敏捷开发实战:从零搭建Scrum团队的全流程指南(含KANBAN配置)
Jira敏捷开发实战:从零搭建Scrum团队的全流程指南(含KANBAN配置) 在数字化转型浪潮中,敏捷开发已成为提升团队效能的利器。作为全球领先的项目管理工具,Jira以其灵活的配置和强大的可视化功能,成为Scrum团队…...
别让论文卡住你毕业!热门工具毕业之家和PaperRed,从出稿到过审全包了
当前市面上的论文写作工具琳琅满目,但真正经过市场验证、口碑扎实的并不多。今天为你重点介绍两款热门工具——毕业之家和PaperRed,它们在2026年毕业生中广受好评,分别代表了“全流程管家”和“降重专家”两种不同定位。-10 一、毕业之家&am…...
5个创新方法:用WindowResizer智能解决窗口尺寸管理难题
5个创新方法:用WindowResizer智能解决窗口尺寸管理难题 【免费下载链接】WindowResizer 一个可以强制调整应用程序窗口大小的工具 项目地址: https://gitcode.com/gh_mirrors/wi/WindowResizer 你是否曾被那些"顽固"的应用程序窗口困扰过ÿ…...
终极指南:如何用QCMA彻底解放你的PS Vita内容管理
终极指南:如何用QCMA彻底解放你的PS Vita内容管理 【免费下载链接】qcma Cross-platform content manager assistant for the PS Vita 项目地址: https://gitcode.com/gh_mirrors/qc/qcma 还在为PS Vita官方Content Manager Assistant的种种限制而烦恼吗&…...
如何永久保存微信聊天记录?WeChatMsg免费开源工具终极指南
如何永久保存微信聊天记录?WeChatMsg免费开源工具终极指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/W…...
HarmonyOS 6学习:Swiper组件圆点指示器颜色叠加问题解析与解决方案
一、前言:一个看似简单却困扰开发者的视觉问题在HarmonyOS应用开发中,Swiper组件作为实现轮播图、图片浏览、引导页等功能的利器,被广泛应用于各类应用场景。其内置的圆点指示器(indicator)功能,为用户提供…...
“交织现实与虚拟:CCP-RIE在AR/VR工业动画中的创新展现“
在半导体制造领域,电容耦合等离子体反应离子刻蚀(CCP-RIE)作为一种关键的刻蚀技术,正继续推动微电子器件和纳米技术的发展。而随着AR/VR技术的进步,3D动画开始在工业应用中体现出强大的优势。本文将探讨CCP-RIE技术的细节及其与3D动画相结合在…...
MetaWRAP数据库安装卡在下载?试试这个Aspera ascp参数详解与速度优化方案
MetaWRAP数据库下载卡顿?Aspera ascp参数深度调优指南 当你在深夜的实验室服务器前,盯着屏幕上缓慢蠕动的进度条——那个已经持续了8小时的NCBI数据库下载任务,突然意识到生物信息学研究中最耗时的可能不是分析代码运行,而是等待数…...
