关于分治法左右区间单调遍历应该如何设计

阅读以下文章,首先至少要求通过一道分治法的题目或听过一道该类型的讲解。

对于分治的题目,想必你应该知道,通常我们是对于一个区间拆分两个部分,而最小子问题通常是只包含一个元素的区间数组。为了后续方便处理更大范围的区间,通常在处理该小区间后,我们会将其区间内元素排序,例如下面例子:

该例子是求:对于右区间的每个元素,求右侧大于左侧的元素个树,比如左数组为 2 3 右数组为:4 3,那么对于4来说2 3 两个都比4小,对于右侧的3来说只有2比他小,所以结果为3
在这里插入图片描述

很显然,我们可以使用两个指针,暴力遍历所有,直接求出答案,而该代码的时间复杂度为O( n 2 n^2 n2)

public static int GetKey(){int res=0;for(;left<mid=;left++){for(;right<=n;right++){   //n为区间最右端res+=num[right]>num[left]?1:0; //满足则加1,不满足则不加}}return res;
} 

在一次期末考试后,班主任决定颁发奖励,满足一定方式的学生都可以获得某个等级的奖励,对于分数高的同学既可以获取一等奖,也可以获取二,三等奖。聪明的班主任想到快速的方法分配奖励,他先将分数从低到高排序,他先从低级奖励分配,每次分配奖励,他先看看学生的分数,由于学生分数以排序,从左往右数,直到找到满足分数的学生,剔除前面的学生,毕竟连当前奖励分数都不满足,那么必定与后面的奖励无缘了,每分配下一等级的奖励,他都循环这一步骤。
这个故事是有一定的开导性的。
自然可以想到一种更好的方法了(对于有单调性的题目一般都可以,所谓单调性是:如果a>b,b>c,一定有a>c)
那就是左右两侧都先排序,利用有序性,则可以减少大部分的计算,例如下图

1.右指针指向的元素是大于左指针指向的元素,由于排序后,右指针后面的其实都大于左指针指向的元素,所以大于23的右侧元素个数为区间右端减去右指针再加1。
2.然而聪明的你意思到,这并不对,因为你怎么确定右指针的左侧不会有比23大的树呢,其实对于左右指针的控制确保了右指针的前面不会存在比左指针大的情况的。在这里插入图片描述

public static int GetKey(){for(;left<=mid;left++){          //遍历每一个需要满足的条件while(right<n&&num[right]<=num[left]){      //向右寻找满足条件的元素right++;           }if(right<n){       //如果有满足元素的话res+=n-1-right+1;     //n-1代表区间最右下标}else{break;  //当前过滤的没有满足的元素了,那么后面更不可能了}}	return res;
}

仔细观察该代码,是不是发现右指针前面的元素一定不会大于左指针的呢!

刚学完,来试试可不可以立即想到一种解决方案,毕竟不是所有题的单调性都是这么直观的。
数组还是上面的图片,但是条件换为num[left]>num[right]*2。

这与上面的题目类似,只不过是左右大小条件换了,变成左侧大于右侧,那么你可以把条件当作右侧,分数当作左侧(引用上面的故事)。

以下是答案

public static int GetKey(){for(;right<n;right++){int res=0;while(left<=mid&&num[left]<=num[right]){left++;}if(left<=mid){res+=mid-left+1;}}return res;
}

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Mybatis的分页插件的使用方式

插件介绍: 使用mabatis中一个名为PageHelper的插件,会把我们后面的一条SQL进行一个动态的拼接,通过拦截器对sql动态的添加limit,从而实现分页的效果 使用方式: 1.先导入相关的依赖 2.在项目中的Mapper层中对应的Mapper.xml中写动态SQL 3.在项目中的Serviceimpl层通过PageHel…

计算机信息处理技术

信息技术基础知识 数据和信息 数据 “数据是对事实、概念或指令的一种特殊表达形式&#xff0c;这种特殊表达形式可以用人工的方式或者用自动化的装置进行通信&#xff0c;翻译转换或者进行加工处理。”根据这个定义&#xff0c;数字、文字、图形、图像、声音等都是数据。数…

基于Python的膳食健康系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

Kafka面试题(三)

1、kafka是如何做到高效读写 1&#xff09;Kafka 本身是分布式集群&#xff0c;可以采用分区技术&#xff0c;并行度高。 2&#xff09;读数据采用稀疏索引&#xff0c;可以快速定位要消费的数据。&#xff08;mysql中索引多了之后&#xff0c;写入速度就慢了&#xff09;。 …

【Pikachu】任意文件上传实战

将过去和羁绊全部丢弃&#xff0c;不要吝惜那为了梦想流下的泪水。 1.不安全的文件上传漏洞概述 不安全的文件上传漏洞概述 文件上传功能在web应用系统很常见&#xff0c;比如很多网站注册的时候需要上传头像、上传附件等等。当用户点击上传按钮后&#xff0c;后台会对上传的…

C++【STL容器系列(二)】vector的模拟实现

文章目录 1. vector的结构2. vector的默认成员函数2.1构造函数2.1.1 默认构造2.1.2 迭代器构造2.1.3 用n个val初始化构造 2.2 拷贝构造2.3 析构函数2.4 operator 3. vector iterator函数3.1 begin 和 cbegin函数3.2 end() 和 cend()函数 4. vector的小函数4.1 size函数4.2 capa…

边缘检测的100种方法

文章目录 什么是边缘检测 ?一、边缘检测算子&#xff1a;Sobel算子、Scharr算子、Laplacian算子、Canny算子二、梯度计算 顶帽 黑帽 拉普拉斯金字塔三、相位一致性&#xff08;Phase Congruency&#xff0c;PC&#xff09;3.1、底层代码&#xff08;2D&#xff09;3.2、ski…

【Linux探索学习】第十二弹——初识进程:进程的定义、描述和一些简单的相关操作

Linux学习笔记&#xff1a; https://blog.csdn.net/2301_80220607/category_12805278.html?spm1001.2014.3001.5482 前言&#xff1a; 在前面经过那么多篇的铺垫后&#xff0c;今天我们正式进入Linux学习的第一个重难点——进程&#xff0c;理解进程对于我们学习操作系统的其…

Java项目实战II基于微信小程序的订餐系统(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导 一、前言 随着移动互联网技术的飞速发展&#xff0…

触想染织厂MES产线终端工位机,打造数字化高效车间

一、行业发展背景 在纺织细分领域中&#xff0c;印染行业一直是整个产业链的效率短板&#xff0c;因其涉及染色、定型及后整理加工等多个复杂工艺、上百个参数变量&#xff0c;质量波动较大&#xff0c;依赖个人经验和手工操作&#xff0c;常常陷入高成本、低效率发展困境。 △…

CSS查缺补漏 two

11.6~11.11查缺补漏 一、熟记1.结构伪类选择器2.伪元素选择器3.盒子模型4.居中对齐&#xff08;重中之重&#xff01;&#xff01;&#xff01;&#xff09;5.清除默认样式6.元素溢出&#xff08;滚动条&#xff09;7.行内元素 – 内外边距问题8.圆角9 .盒子阴影&#xff08;拓…

Taro React-Native IOS 打包发布

http网络请求不到 配置 fix react-native facebook::flipper::SocketCertificateProvider‘ (aka ‘int‘) is not a function or func_rn运行debug提示flipper-CSDN博客 Xcode 15&#xff08;iOS17&#xff09;编译适配报错_no template named function in namespace std-CS…

本地搭建你的私有网盘:在Ubuntu上使用Portainer CE安装NextCloud

文章目录 前言1. 在PortainerCE中创建NextCloud容器2. 公网远程访问本地NextCloud容器2.1 内网穿透工具安装3.2 创建远程连接公网地址 3. 固定NextCloud私有云盘公网地址 前言 本篇文章介绍如何在本地使用Portainer CE可视化图形界面创建NextCloud私有网盘容器&#xff0c;并结…

超好用shell脚本NuShell mac安装

利用管道控制任意系统 Nu 可以在 Linux、macOS 和 Windows 上运行。一次学习&#xff0c;处处可用。 一切皆数据 Nu 管道使用结构化数据&#xff0c;你可以用同样的方式安全地选择&#xff0c;过滤和排序。停止解析字符串&#xff0c;开始解决问题。 强大的插件系统 具备强…

游戏引擎中LOD渲染技术

一.LOD(Level Of Detail) 为了降低GPU渲染压力,根据摄像机距离模型距离将面数较高的模型替换为面数较低的模型. LOD LOD0(distance<10) LOD1(distance<20) LOD2(distance<30) 故通常引擎中MetaMesh是由一个或多个LOD模型构成. MetaMesh mesh mesh.lod1 mesh.lod…

web前端动画按钮(附源代码)

效果图 源代码 HTML部分 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> …

昇思大模型平台打卡体验活动:项目5基于MindSpore实现Transformer机器翻译

首先仍然是先登录大模型体验平台 https://xihe.mindspore.cn/my/clouddev 启动&#xff01;&#xff01; 进入环境之后&#xff0c;即可开始运行notebook&#xff0c; Transformer 模型与实现 Transformer 是一种由 Vaswani 等人在 2017 年提出的神经网络结构&#xff08;论文…

‌关于人工智能(AI)的发展现状和未来趋势的详细分析!

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///C爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日将继续分享关于‌人工智能&#xff08;AI&#x…

提高排名的有效策略与实践指南

内容概要 在现代数字化时代&#xff0c;提高排名不仅是企业营销的关键&#xff0c;更是提升品牌知名度和客户粘性的有效途径。为了更好地理解这一主题&#xff0c;我们从多个方面进行详细分析。首先&#xff0c;明确"排名"的基本概念是非常重要的&#xff0c;它通常…

【Linux】动静态库

目录 1、制作静态库 2、站在使用者角度使用库 3、制作动态库 4、动态库是怎么被加载的 1、制作静态库 之前对动静态库的认识&#xff1a; libXXX.a-----静态库 静态链接&#xff1a;将库当中的代码拷贝到最终的可执行程序里&#xff0c;也就是&#xff0c;自己的源代码会变成…