算法刷题笔记 数的范围(C++实现)(二分法重要例题)

文章目录

    • 题目描述
    • 题目思路
    • 题目代码(C++)
    • 题目感想

题目描述

  • 给定一个按照升序排列的长度为n的整数数组,以及q个查询。
  • 对于每个查询,返回一个元素k的起始位置和终止位置(位置从0开始计数)。
  • 如果数组中不存在该元素,则返回 -1 -1

输入格式

  • 第一行包含整数nq,表示数组长度和询问个数。
  • 第二行包含n个整数(均在1∼10000范围内),表示完整数组。
  • 接下来q行,每行包含一个整数k,表示一个询问元素。

输出格式

  • q行,每行包含两个整数,表示所求元素的起始位置和终止位置。
  • 如果数组中不存在该元素,则返回 -1 -1

题目思路

  • 本题实际上是一个整数二分问题,相当于从一个有序数组中找到两个边界,正好可以用二分查找方法进行解决。
  • 首先,需要找到左边界,即指定的查询数字在数组中的最靠前的出现位置。因此,只需要以中点为参考,判断中点是否满足大于等于需要查询的数值,然后分情况设置下一个区间即可。重复这种情况,直到左右端点重合,则返回此时的点。
    • 如果中点对应的值确实大于等于需要查询的数值,则说明需要查询的数值在以中点为划分的左半边区间内(这个区间包含了上一步的中点),因此将区间的右端点修改为当前的中心点。
    • 如果中点对应的值小于需要查询的数值,则说明需要查询的数值在以中点为划分的右半区间内(这个区间不包含中点,因为中点的值小于查找的值),因此将区间的左端点设置为当前中心点右边的第一个端点即可。

为什么判定条件是大于等于而不是小于等于:如果采用小于等于,则会将原始的有序数组划分为大于等于查询值和小于查询值的两部分,此时,每一次如果中点小于等于当前查询的值,那么左端点可能在中点的右边(即中点实际是小于查询值的)或中点的左边(查询值有多个位置,中点并非最靠左的一个),因此无法继续二分。

为什么判定条件不使用大于或小于:以大于为例,如果采用大于,则会将原始的有序数组划分为大于查询值和小于等于查询值的两部分。此时,每一次如果中点大于当前查询的值,一定可以判定待查询的值一定在左半边区间内,但是如果中点小于等于查询值,则无法判定左边界的位置,因为左边界可能在中点左边(当中点等于查询值,且不是排在最前面的时候)或中点右边(中点小于查询值时)。

  • 如果此时返回的端点仍然不等于需要查找的值,说明原始数组中不存在和需要查找的值相等的元素,输出 -1 -1;否则,继续进行后续的步骤。
  • 后续步骤即为找出区间的右端点。与找出左端点类似,但是将条件修改为判断中点是否满足小于等于需要查询的数值。当中点小于等于需要查询的数值的时候,说明其一定在以右边界为轴点的左边区间中,因此将区间的左端点设置为右边界即可;当中点大于需要查询的数值的时候,说明其一定在以右边界为轴点(不包括右边界)的右边区间中,因此将区间的右端点设置为中点向左移动一个单位后的端点即可。

题目代码(C++)

#include <cstdio>int n,q;
const int N(1e5 + 10);
int arr[N];
int query;int main(void)
{scanf("%d %d", &n, &q);for(int i(0); i < n; ++i) scanf("%d", &arr[i]);for(int i(0); i < q; ++i) {scanf("%d", &query);int left(0), right(n - 1);while(left < right){int mid((left + right) >> 1);if(arr[mid] >= query) right = mid;else left = mid + 1;}if(arr[left] != query) printf("-1 -1\n");else{printf("%d ",left);left = 0, right = n - 1;while(left < right){int mid((left + right + 1) >> 1);if(arr[mid] <= query) left = mid;else right = mid - 1;}printf("%d\n", right);}}return 0;
}

题目感想

  • 整数二分算法的模板中,需要注意如果是满足条件需要将左边界修改为区间中点(即left = mid),则进行中点位置计算时需要额外加1,否则会出现死循环。
  • 二分的最大难点在于判断使用什么中点判定条件,如上代码所示。
  • 尝试将代码中的所有scanf函数修改为C++中的cin输入方式,发现运行时间天差地别,如下图所示。图中所有两位数的运行时间都是使用scanf得到的结果,三位数的运行时间都是cin得到的结果。
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/14577.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker【2】iptables 错误解决

iptables 错误解决 问题说明问题分析解决步骤1. 确保 iptables 模块已加载2. 检查和重启 docker 服务3. 检查 firewalld 状态4. 重置 iptables 规则5. 查看和更新 Docker 配置 总结 问题说明 执行的 docker 命令如下&#xff0c;启动 nginx 并设置宿主机端口 (8080) 与容器端口…

学习Uni-app开发小程序Day25

这一章学习了触底加载更多阻止无效的网络请求、分类列表存入Storage在预览页面读取缓存展示、通过swiper的事件实现真正的壁纸预览及切换 触底加载更多阻止无效的网络请求、load-more样式的展现 前面已经学习了当列表触底后&#xff0c;会继续加载&#xff0c;当到最后一层后…

自动化测试--利用pytest实现整条业务链路测试

​ 概述 前面一章讲解了单个接口的测试&#xff0c;但是实际项目中&#xff0c;因为权限和登录状态的限制&#xff0c;大部分接口没办法直接访问到&#xff0c;这时候我们想访问到一个系统的接口&#xff0c;就需要模拟用户登录拿到用户的token和所拥有的权限之后再将这些信息…

vivado2020.2创建hls仿真工程实现led闪烁

下载vivado2020.2后会有这个出现在桌面 点击进入创建工程&#xff0c;这里注意不要有前面的\我再复制的时候复制错了导致创建失败 按f光标就会跳转到下一个f开头的函数处&#xff0c;要查找其他函数也同理 生成了一个synthesis summary文件 找到目录下生成的.v文件 an 点…

Pod进阶——资源限制以及探针检查

目录 一、资源限制 1、资源限制定义&#xff1a; 2、资源限制request和limit资源约束 3、Pod和容器的资源请求和限制 4、官方文档示例 5、CPU资源单位 6、内存资源单位 7、资源限制实例 ①编写yaml资源配置清单 ②释放内存&#xff08;node节点&#xff0c;以node01为…

【知识蒸馏】多任务模型 logit-based 知识蒸馏实战

一、什么是逻辑&#xff08;logit&#xff09;知识蒸馏 Feature-based蒸馏原理是知识蒸馏中的一种重要方法&#xff0c;其关键在于利用教师模型的隐藏层特征来指导学生模型的学习过程。这种蒸馏方式旨在使学生模型能够学习到教师模型在特征提取和表示方面的能力&#xff0c;从…

有些错误,常犯常新、常新常犯:记录一个使用element-plus的tooltip组件的错误

使用element-plus的tooltip组件&#xff0c;最开始的写法是这样的&#xff1a; <el-tooltipclass"box-item"effect"dark"content"tooltip content" ><el-button v-if"isDisabled" :underline"false" type"pr…

持续总结中!2024年面试必问 20 道 Redis面试题(五)

上一篇地址&#xff1a;持续总结中&#xff01;2024年面试必问 20 道 Redis面试题&#xff08;四&#xff09;-CSDN博客 九、Redis的同步机制了解么&#xff1f; Redis 的同步机制是其复制策略的核心部分&#xff0c;确保数据在主节点&#xff08;master&#xff09;和从节点…

【C语言】程序员自我修养之文件操作

【C语言】程序员自我修养之文件操作 &#x1f525;个人主页&#xff1a;大白的编程日记 &#x1f525;专栏&#xff1a;C语言学习之路 文章目录 【C语言】程序员自我修养之文件操作前言一.文件介绍1.1为什么使用文件1.2文件分类1.3二进制文件和文本文件 二.文件的打开和关闭2.…

桌面藏线大法

1有线改无线&#xff1a; 蓝牙鼠标 蓝牙键盘 蓝牙耳机 2将排插贴到桌子底下 购物软件上搜 3断舍离 不要的电子产品统统扔掉 4 洞洞板和挂钩 这个不用介绍了

爬虫基本原理及requests库用法

文章目录 一、爬虫基本原理1、什么是爬虫2、爬虫的分类3、网址的构成4、爬虫的基本步骤5、动态【异步】页面和静态【同步】页面6、请求头 二、requests基本原理及使用1、chrome 抓包按钮详解1.1 Elements1.2 元素定位器1.3 Network1.4 All1.5 XHR1.6 Preserve log1.7 手机模式1…

暴雨信息液冷计算解决方案亮相CCIG 2024

5月24日&#xff0c;2024中国图象图形大会&#xff08;CCIG&#xff09;在陕西西安正式开幕。作为涵盖图像图形各专业领域的综合性的全国性学术会议&#xff0c;CCIG面向开放创新、交叉融合的发展趋势&#xff0c;为图像图形相关领域的专家学者和产业界的同仁&#xff0c;搭建了…

Java+Spring+ MySQL + MyCat云HIS有哪些优势?智慧医疗云(HIS)低成本与安全保障的完美结合

JavaSpring MySQL MyCat云HIS有哪些优势&#xff1f;智慧医疗云(HIS)低成本与安全保障的完美结合 云HIS的优点包括节省成本、便捷高效、稳妥安全等。通过云HIS&#xff0c;医疗机构无需在本地建立机房、购买服务器和应用软件&#xff0c;降低了硬件和人力成本。同时&#xff0…

虚拟化介绍

虚拟化介绍 概述概念特点优势实现手段 虚拟化架构概述寄居虚拟化架构裸金属虚拟化架构操作系统虚拟化架构混合虚拟化架构几种虚拟化架构的比较虚拟化架构与虚拟化技术的关系 虚拟化技术分类服务器虚拟化技术分类 存储虚拟化技术分类网络虚拟化技术分类 服务器虚拟化技术处理器虚…

开源软件 | 一文彻底搞懂许可证的定义、起源、分类及八大主流许可证,让你选型不再头疼

为什么开源软件会存在许可证&#xff0c;许可证的起源与产生目的是为了解决什么问题&#xff1f;许可证的定义又是怎样的&#xff1f;什么是Copyleft&#xff0c;与Copyright有何区别&#xff1f;开源软件常见的许可证有哪些&#xff1f;这些许可证都有什么特点&#xff1f;接下…

[c++] 小游戏 能量1.0.1 版本 zty出品

大家好 紧急修改&#xff0c;发现判断游戏是否结束部分有问题&#xff0c;紧急修改bug&#xff0c;对大家造成的不便我深感歉意&#xff0c;对不起 先赞后看 养成习惯 code&#xff1a; #include<bits/stdc.h> #include<windows.h> using namespace std; int rg…

Zabbix实现7x24小时架构监控

上篇&#xff1a;https://blog.csdn.net/Lzcsfg/article/details/138774511 文章目录 Zabbix功能介绍Zabbix平台选择安装Zabbix监控端部署MySQL数据库Zabbix参数介绍登录Zabbix WEBWEB界面概览修改WEB界面语言添加被控主机导入监控模板主机绑定模板查看主机状态查看监控数据解…

6.封装读写游戏数据的功能

前置知识&#xff1a;5.模仿CheatEngine实现锁血无敌功能&#xff08;封装它的代码&#xff09; 封装功能.cpp文件 #include "封装功能.h"GAMECheat::GAMECheat(unsigned pid, unsigned _baseAdr, unsigned _readTime) {readTime _readTime;baseAdr _baseAdr;hPr…

代码随想录算法训练营第三十四天 | 理论基础、455.分发饼干、376、摆动序列、53.最大子序和

目录 理论基础 455.分发饼干 思路 代码 376.摆动序列 思路 代码 53.最大子序和 思路 代码 理论基础 代码随想录 455.分发饼干 代码随想录 思路 可以是大饼干优先满足大胃口&#xff0c;也可以是小饼干优先满足小胃口。 代码 class Solution:def findContentChildre…

ArkUI-X开发指南:【SDK配置和构建说明】

ArkUI-X SDK配置和构建说明 ArkUI-X SDK是ArkUI-X开源项目的编译产物&#xff0c;可将ArkUI-X SDK集成到现有Android和iOS应用工程中&#xff0c;使开发者基于一套ArkTS主代码&#xff0c;就可以构建支持多平台的精美、高性能应用。SDK内容包含ArkUI跨平台运行时&#xff0c;组…