1236. 递增三元组:做题笔记

目录

暴力

代码

二分

代码

前缀和 

代码

推荐视频讲解


暴力

这道题说的是有三个元素数量相同的数组,想知道有多少个三元组满足:三个数分别来自 A B C数组且呈现递增。

我想的是既然要求递增,那就先把数组数据都排一下序,直接sort函数用起来。因为排了序的话就说明在某个数之后的所有数都是满足条件的,直接进行累加就可以。

第一个数A数组肯定要先遍历一下的(是的我当时做的时候压根没想到其他的),我就想着我们既然想利用排完序的好处,那就从这想。

在第一层循环的基础上,在对第二层数据挑选的时候,就可以利用二分找到我们上面所说的“某个数”,这里的某个数其实也就是当前B数组里第一个大于当前外层循环正在处理的A数组的这个元素,我们知道在这个数之后的B数组中的数都是一种选择的可能。同理,到了最内层对从C数组中选的第三个数的可能性也就是在前两个数确定的这种情况下满足条件的可能性。

这样就枚举了所有可能性,肯定超时的。且这样的写法一个数据都过不了呜呜😭

我就没想到到底怎么优化掉第二层循环,,

代码

#include<iostream>
#include<algorithm>
using namespace std;
#define int long long
const int N=1e5+10;
int a[N],b[N],c[N],b1[N],c1[N];
int n;
int find(int q[],int x)
{int l=0,r=n;while(l<r){int mid=(l+r)/2;if(q[mid]>x)r=mid-1;else l=mid;}if(q[l]>x)return l;else if(q[l]==x)return l+1;else return -1;
}
signed main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);cin>>n;for(int i=0;i<n;i++)cin>>a[i];for(int i=0;i<n;i++)cin>>b[i];for(int i=0;i<n;i++)cin>>c[i];sort(a, a+n);sort(b, b+n);sort(c, c+n);int cnt=0;for(int i=0;i<n;i++){for(int j=find(b,a[i]);j<n;j++){//第三层循环还是好优化的(不过没什么卵用,因为双层循环仍然tle😜)/*for(int k=find(c,b[j]);k<n && k!=-1;k++){cnt++;}*/int k=find(c,b[j]);cnt+=n-k;}}cout<<cnt;return 0;} 

二分

就是看了讲解才知道我们想降成一层循环,那留下来的这层循环就必须是中间的B数组。

因为A B C 三元组想递增嘛,那 A<B,C>B。遍历B数组每个元素,可以通过二分找到A数组中第一个大于当前B数组中元素的数的位置,和C数组中第一个大于当前B数组中元素的数的位置,通过元素总数与该位置的相减,得到其中间的元素个数。

我们可以写二分模板,也可以使用 lower_bound和upper_bound 函数,感觉直接用函数很方便。就像那个sort函数一样。

由于这两个函数的操作对象应该是有序的,我们需要对数组进行排序。

补充一下这两个函数的用法:

lower_bound(begin, end, value):在从小到大排好序的数组中,在数组的 [begin, end) 区间中二分查找第一个大于或等于value的数,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标


upper_bound(begin, end, value):在从小到大排好序的数组中,在数组的 [begin, end) 区间中二分查找第一个大于value的数,找到返回该数字的地址,不存在则返回end。通过返回的地址减去起始地址begin,得到找到数字在数组中的下标。


这两个函数的时间复杂度都是O(logN),其中N是搜索空间中的元素数量。 

代码

#include<iostream>
#include<algorithm>
using namespace std;
#define int long long
const int N=1e5+10;
int a[N],b[N],c[N];
int n;
signed main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);cin>>n;for(int i=0;i<n;i++)cin>>a[i];for(int i=0;i<n;i++)cin>>b[i];for(int i=0;i<n;i++)cin>>c[i];sort(a, a+n);sort(b, b+n);sort(c, c+n);int cnt=0;for(int i=0;i<n;i++){int l=lower_bound(a,a+n,b[i])-a,r=n-(upper_bound(c,c+n,b[i])-c);cnt+=l*r;}cout<<cnt;return 0;}

l 是数组 a 中小于 b[i] 的元素的数量,r 是数组 c 中大于 b[i] 的元素的数量。

前缀和 

这里前缀和的思路也是以B数组的遍历为主。

记录下所有数字出现的次数,预处理出前缀和,对A C数组进行排序,与B数组当前处理的元素进行比较,通过前缀和的运算得到A数组小于当前元素的个数,和C数组大于当前元素的个数,将这两个数相乘,并随着B数组的遍历对每一种情况进行累加得到最终结果。

关于前缀和的运算:A数组想得到小于当前元素的个数,直接b[i]-1的前缀和得到的就是想要的区间的前缀和  ( sa[b[i]-1] )

C数组想得到大于当前元素的个数,用 N 处的前缀和减去b[i]当前元素的前缀和即可( sc[N]-sc[b[i]] )

需要注意的是,由于数组中每个元素的数据范围是0-1e5,因此在前缀和计算中要从0开始,循环1e5次,关于数组越界问题:

代码

#include<iostream>
#include<algorithm>
using namespace std;
#define int long long
const int N=1e5+10;
int a[N],b[N],c[N];
int a1[N],c1[N];//存放每个数出现次数
int sa[N],sc[N];//计算a1,c1的前缀和
int as[N],cs[N];//通过前缀和的运算处理出所有可能的情况
//as代表比b[i]小的数的个数  cs代表比b[i]大的数的个数
int n;
signed main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);cin>>n;for(int i=0;i<n;i++)cin>>a[i];for(int i=0;i<n;i++)cin>>b[i];for(int i=0;i<n;i++)cin>>c[i];for(int i=0;i<n;i++)a1[a[i]]++;for(int i=0;i<=N;i++)sa[i]=sa[i-1]+a1[i];for(int i=0;i<n;i++)as[i]=sa[b[i]-1];for(int i=0;i<n;i++)c1[c[i]]++;for(int i=0;i<=N;i++)sc[i]=sc[i-1]+c1[i];for(int i=0;i<n;i++)cs[i]=sc[N]-sc[b[i]];int cnt=0;for(int i=0;i<n;i++){cnt+=as[i]*cs[i];}cout<<cnt;return 0;}

推荐视频讲解

【蓝桥杯真题,递增三元组,前缀和问题】

老师讲的很清晰。推荐观看

AcWing 1236. 递增三元组(三种算法+胎教注释)​​​​​​​

这个题解不知道大家能看到不能。


感觉思路理解还行,但是就是明白了思路到写对题之间还有很长距离,好多细节问题emm. 

哎好难🥀🥀🥀🥀

有问题欢迎指出,一起加油!!!!

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

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

相关文章

springCloudAlibaba集成gateWay实战(详解)

一、初识网关&#xff1f; 1、网关介绍 ​ 在微服务架构中&#xff0c;一个系统会被拆分为很多个微服务。那么作为客户端要如何去调用这么多的微服务呢&#xff1f;如果没有网关的存在&#xff0c;我们只能在客户端记录每个微服务的地址&#xff0c;然后分别去调用。这样的话…

SpringMVC源码分析(九)--返回值解析器

1.返回值解析器介绍 返回值解析器用于解析Hanlder执行方法后的返回结果,例如将方法上标注有@ResponseBody注解的返回值解析成JSON、将方法返回的字符串作为视图名等 SpringMVC中默认的返回值解析器见RequestMappingHandlerAdapter#getDefaultReturnValueHandlers private L…

灵活的云计算:可移植性架构的多维优势

Bottom of Form 从敏捷开发的视角来看&#xff0c;大多数场景下&#xff0c;我们在构建应用程序时&#xff0c;都会希望实现快速开发、缩短上线周期&#xff0c;并充分利用云提供商的成型组件服务&#xff0c;来获得更好的稳定性。若想要达成理想成果&#xff0c;我们在具体过…

【opencv】教程代码 —features2D(8)AKAZE 特征点匹配和图像拼接

graf1.png graf3.png <?xml version"1.0"?> <opencv_storage> <H13 type_id"opencv-matrix"><rows>3</rows><cols>3</cols><dt>d</dt><data>7.6285898e-01 -2.9922929e-01 2.2567123e02…

matlab碰撞检测

文章目录 碰撞对象collisionCylindercollisionBoxcollisionMeshcollisionSpherecollisionCapsulecheckCollisionfitCollisionCapsuleshowCollisionArraycapsuleApproximationaddCapsuleremoveCapsuleconvertToCollisionMesh碰撞对象 函数功能checkCollision检测两几何体是否存在…

【WPF应用26】C#中的CheckBox控件详解与应用示例

在WPF&#xff08;Windows Presentation Foundation&#xff09;应用中&#xff0c;C#中的CheckBox控件是一种常用的用户界面元素&#xff0c;允许用户从多个选项中选择一个或多个选项。本文将详细介绍CheckBox控件的功能、使用方法以及在应用程序中的具体应用示例。 1. Check…

前端之CSS——网页的皮肤!!

目录 一、CSS简单介绍 二、css内容 2.1 css的编写方式 2.2 css选择器 2.3 样式属性 2.4 css包围盒 2.5 css中的display 2.6 css中的定位 2.7 css中的浮动与清除 2.7 弹性容器 2.8 字体图标 2.9 …

Databricks声称DBRX为开源大型语言模型设定了“一个新标准”

Databricks宣布推出DBRX&#xff0c;这是一款强大的新开源大型语言模型&#xff0c;据称它通过在行业基准测试中超越了像GPT-3.5这样的既定选项&#xff0c;为开放模型设定了新的标准。 该公司表示&#xff0c;具有1320亿参数的DBRX模型在语言理解、编程和数学任务上超越了流行…

如何在 xcode 中使用 string catalogs

在iOS开发中&#xff0c;xcstrings和strings文件在本质上是相似的&#xff0c;但在Xcode 15中引入的Strings Catalogs中有一些重要区别。 xcstrings文件是Strings Catalogs的一部分&#xff0c;它们可以作为单个源文件包含应用程序的所有本地化字符串内容&#xff0c;包括常规…

1.5编写一个程序,输入梯形的上底,下底和高,输出梯形的面积。

1、编写一个程序,输入梯形的上底,下底和高,输出梯形的面积。 package com.kangning.web.controller.system;import java.util.Scanner;/*** 编写一个程序,输入梯形的上底,下底和高,输出梯形的面积。*/ public class CountArea {public static void main(String[] args) …

面向对象编程中的StringBuffer类详解

咦咦咦&#xff0c;各位小可爱&#xff0c;我是你们的好伙伴——bug菌&#xff0c;今天又来给大家普及Java SE相关知识点了&#xff0c;别躲起来啊&#xff0c;听我讲干货还不快点赞&#xff0c;赞多了我就有动力讲得更嗨啦&#xff01;所以呀&#xff0c;养成先点赞后阅读的好…

【Linux 驱动基础】设备树驱动

# 前置知识 在图中&#xff0c;树的主干就是系统总线&#xff0c; IIC 控制器、 SPI 控制器等都是接到系统主线上的分支。其中 IIC1 上接了 AT24C02这个 IIC 设备&#xff0c; DTS 文件的主要功能就是按照图所示的结构来描述板子上的设备信息。 1. Device格式 DTS文件格式 …

【论文阅读】ELA: Efficient Local Attention for Deep Convolutional Neural Networks

&#xff08;ELA&#xff09;Efficient Local Attention for Deep Convolutional Neural Networks 论文链接&#xff1a;ELA: Efficient Local Attention for Deep Convolutional Neural Networks (arxiv.org) 作者&#xff1a;Wei Xu, Yi Wan 单位&#xff1a;兰州大学信息…

IDEA 打包jar

IDEA MAVEN项目打包成jar包的两种简单方式_idea maven打包jar-CSDN博客

基于架构的软件开发方法_1.概述和相关概念及术语

1.体系结构的设计方法概述 基于体系结构的软件设计&#xff08;Architecture-Based Software Design&#xff0c;ABSD&#xff09;方法。ABSD方法是由体系结构驱动的&#xff0c;即指由构成体系结构的商业、质量和功能需求的组合驱动的。 使用ABSD方法&#xff0c;设计活动可以…

C++项目——集群聊天服务器项目(十一)服务器异常退出与添加好友业务

本节来实现C集群聊天服务器项目中的服务器异常退出与添加好友业务&#xff0c;一起来试试吧 一、服务器异常退出 在Linux环境下&#xff0c;我们在服务器端使用CTRLC结束程序执行&#xff0c;即使用CTRLC让服务器异常退出&#xff0c;这样的后果是本应登录服务器的用户在数据库…

vsCode 刷 leetcode 使用 Cookie 登录

1. 安装插件 打开 vsCode&#xff0c;选择扩展&#xff0c;搜索 leetcode&#xff0c;选择第一个&#xff0c;带有中文力扣字样&#xff0c;安装后重启 2. 切换终端 插件安装成功之后&#xff0c;侧边栏选择 leetcode 菜单&#xff0c;切换终端&#xff0c;选择中文版本&…

jvm 调优的方式

jvm调优 什么是jvm JVM&#xff08;Java虚拟机&#xff09;是Java编程语言的运行环境&#xff0c;它是一个虚拟的计算机&#xff0c;能够将Java字节码&#xff08;.class文件&#xff09;转换为机器码并执行。JVM是Java应用程序和Java平台之间的中间层&#xff0c;它提供了内…

HarmonyOS 应用开发之XML生成、解析与转换

XML&#xff08;可扩展标记语言&#xff09;是一种用于描述数据的标记语言&#xff0c;旨在提供一种通用的方式来传输和存储数据&#xff0c;特别是Web应用程序中经常使用的数据。XML并不预定义标记。因此&#xff0c;XML更加灵活&#xff0c;并且可以适用于广泛的应用领域。 …

APP自动化测试-Appium元素定位之元素等待

一、什么是元素等待 元素等待的意义 在 Appium 自动化测试中,元素等待是一个重要的环节。当脚本执行速度较快,而页面元素尚未加载完成时,就会导致脚本无法定位到元素,从而使执行失败。因此需要设置元素等待,从而增强脚本的健壮性,提高执行效率。元素等待的主要目的是确保…