Atcoder Beginner Contest 410 题解报告

零、前言

经过七七四十九天的分别,本期 ABC 题解又和大家见面啦!

经过七周的奋勇杀题,我终于达成了三个小心愿:

  1. 不吃罚时AK
  2. 上金
  3. 排名 100 100 100 以内 且 Rated(悲催的是,我 ABC400 排名两位数但没Rated)

在这里插入图片描述

咳咳,言归正传,开始讲题:

一、正文

第 A 题 G1

十分简单,即求 K K K 小于等于 a a a 中几个数即可。

代码:

#include <bits/stdc++.h>
using namespace std;
int a[1110];
int main(){int n; cin>>n;for (int i=1; i<=n; i++) cin>>a[i];int k,ans=0; cin>>k;for (int i=1; i<=n; i++){if (a[i]>=k) ans++;}cout<<ans;
} 

第 B 题 Reverse Proxy

本题题意为维护 n n n 个盒子, m m m 次操作,每次可以往特定一个盒子或球数量最小(如有多个则取编号最小的)的盒子里放一个球,问每个球被放进那些盒子里了。

考虑到 n , m ≤ 100 n,m\le 100 n,m100 可以暴力查询球数量最小的盒子编号。

代码:

#include <bits/stdc++.h>
using namespace std;
int a[1110];
int main(){int n,q; cin>>n>>q;for (int i=1; i<=q; i++){int x; cin>>x;if (x!=0) cout<<x<<" ",a[x]++;else{int mn=1000000000,id;for (int i=1; i<=n; i++){if (a[i]<mn) mn=a[i],id=i;}cout<<id<<" "; a[id]++;}}
} 

第 C 题 Rotatable Array

题意为维护一个数组,有三种操作:

  1. 单点修改
  2. 单点查询
  3. 旋转(即把第一个元素放到最后)

我们发现,数组长度不变,旋转 n n n 次可以抵消。

假设我们的下标从 0 0 0 开始,那么旋转 u u u 次的第一个元素就是 a u % n a_{u\% n} au%n

修改、查询第 p p p 个点转化为修改、查询第 ( p + ∑ i = 1 i d k i ) % n (p+\sum_{i=1}^{id} k_i)\% n (p+i=1idki)%n 个点, i d id id 表示当前操作编号, k k k 为旋转次数。

代码:

#include <bits/stdc++.h>
using namespace std;
int a[2000010];
int main(){int n,q,st=0; cin>>n>>q;for (int i=1; i<=n; i++) a[i-1]=i;for (int i=1; i<=q; i++){int op; cin>>op;if (op==1){int p,s; cin>>p>>s; p--;a[(p+st)%n]=s;}else if (op==2){int p; cin>>p; p--;cout<<a[(p+st)%n]<<"\n";}else{int k; cin>>k;st=(st+k)%n;}}
} 

第 D 题 XOR Shortest Walk

一句话题意:给你 n n n 个点 m m m 条边的图,求 1 1 1 n n n 的最小异或路径。

发现 w < 2 10 = 1024 w<2^{10}=1024 w<210=1024,可以维护 o k i , j ok_{i,j} oki,j 表示从 1 1 1 走到 i i i 是否有异或和为 j j j 的路径。

BFS 维护,时间复杂度为 O ( w × ( n + m ) ) O(w\times(n+m)) O(w×(n+m)) 可以通过本题。

代码:

#include <bits/stdc++.h>
using namespace std;
bool vis[2010][2010];
vector <pair<int,int>> vc[2010];
int main(){int n,m; cin>>n>>m;for (int i=1; i<=m; i++){int u,v,w; cin>>u>>v>>w;vc[u].push_back({v,w});}vis[1][0]=1;queue <int> qx,qy;qx.push(1); qy.push(0);while (qx.size()){int x=qx.front(),y=qy.front();qx.pop(); qy.pop();for (auto z:vc[x]){if (!vis[z.first][z.second^y]){vis[z.first][z.second^y]=1;qx.push(z.first); qy.push(z.second^y);}}}for (int i=0; i<=2000; i++){if (vis[n][i]) {cout<<i; return 0;}}cout<<-1;
} 

第 E 题 Battles in a Row

题意:有 n n n 个怪物,每个怪物有两个参数 a i , b i a_i,b_i ai,bi,你也有两个参数 A , B A,B A,B。你可以令你的 A A A 减去 a i a_i ai B B B 减去 b i b_i bi 来杀死怪物 i i i,你的 A , B A,B A,B 不能变为负数。问 依次杀死怪物,你能杀死几个呢?

特别提醒标黑部分(本蒟蒻读错题不会做卡了 20min

考虑二分,二分一个怪物数量。对于前 m i d mid mid 个怪物,我们先把默认每个怪物都用 A A A 杀,然后把 b b b 作为代价, a a a 作为价值, B B B 为容量跑背包,跑出最大价值 v v v,发现如果 ( ∑ a ) − v ≤ A (\sum a)-v\le A (a)vA,则有解。

其实不用二分也可以,但我赛时没写。

代码:

#include <bits/stdc++.h>
using namespace std;
#define N 500000
int x[N],y[N],n,a,b,dp[N];
bool check(int mid){int sum=0;for (int i=1; i<=mid; i++) sum+=x[i];memset(dp,0,sizeof(dp));for (int i=1; i<=mid; i++){for (int j=b; j>=y[i]; j--){dp[j]=max(dp[j],dp[j-y[i]]+x[i]);}}return sum-dp[b]<=a;
}
int main(){ios::sync_with_stdio(0);cin.tie(0); cout.tie(0);cin>>n>>a>>b;for (int i=1; i<=n; i++){cin>>x[i]>>y[i];}int l=0,r=n;while (l<r-1){int mid=(l+r>>1);if (check(mid)) l=mid;else r=mid;}if (check(r)) cout<<r;else cout<<l;
} 

第 F 题 Balanced Rectangles

一句话题意,给你一个黑白网格,求多少子矩阵内黑白数量相等。

首先注意到 H × W ≤ 300000 H\times W\le 300000 H×W300000,则 H × W × min ⁡ ( H , W ) ≤ 300000 × 300000 = 164316767 H\times W\times \min(H,W)\le 300000\times \sqrt{300000}=164316767 H×W×min(H,W)300000×300000 =164316767,考虑这个时间复杂度。

首先你可以把黑设为 1 1 1,白为 − 1 -1 1,跑二维前缀和,那么假设 H ≤ W H\le W HW

枚举 u , d u,d u,d,满足 1 ≤ u ≤ d ≤ H 1\le u\le d\le H 1udH,然后根据前缀和,我们可以求出每个紫矩阵的权值和,任选两个(红,绿)矩阵,如果它们权值相等,则构成一个可行答案(黑)。
在这里插入图片描述
那么请使用桶来统计答案,时间复杂度为上述值。

如果 H > W H > W H>W,同理枚举两列即可。

代码:

#include <bits/stdc++.h>
using namespace std;
#define K 500000
int cnt[K+K+K];
string s[K];
vector <int> sum[K];
int main(){ios::sync_with_stdio(0);cin.tie(0); cout.tie(0);int t; cin>>t;while (t--){int n,m; cin>>n>>m;for (int i=1; i<=n; i++) cin>>s[i],s[i]=" "+s[i];for (int i=0; i<=n; i++){sum[i].clear();for (int j=0; j<=m; j++){sum[i].push_back(((i==0||j==0)?0:(s[i][j]=='.'?1:-1)));}}for (int i=1; i<=n; i++){for (int j=1; j<=m; j++) sum[i][j]+=sum[i][j-1];}for (int i=1; i<=n; i++){for (int j=1; j<=m; j++) sum[i][j]+=sum[i-1][j];}if (n<=m){long long ans=0;for (int i=1; i<=n; i++){for (int j=i; j<=n; j++){cnt[K]++;for (int k=1; k<=m; k++){ans+=cnt[sum[j][k]-sum[i-1][k]+K];cnt[sum[j][k]-sum[i-1][k]+K]++;}for (int k=1; k<=m; k++){cnt[sum[j][k]-sum[i-1][k]+K]--;}cnt[K]--;}}cout<<ans<<"\n";}else{long long ans=0;for (int i=1; i<=m; i++){for (int j=i; j<=m; j++){cnt[K]++;for (int k=1; k<=n; k++){ans+=cnt[sum[k][j]-sum[k][i-1]+K];cnt[sum[k][j]-sum[k][i-1]+K]++;}for (int k=1; k<=n; k++){cnt[sum[k][j]-sum[k][i-1]+K]--;}cnt[K]--;}}cout<<ans<<"\n";}}
} 

第 G 题 Longest Chord Chain

一句话题意:一个圆上有一些弦,保留互不相交的一些弦,再画一条弦,求问它们之间最多存在多少个交点。

猜结论:保留最多的弦,使得它们可以分成两部分,每部分都依次包含,两部分无交集。

看如下图:
在这里插入图片描述
可以粗略证明上述结论。

现在考虑如何求解,首先假设 a i < b i a_i<b_i ai<bi(可以交换两者),接下来把 a a a 从大到小排序,设 d p i dp_i dpi 为第 i i i 个弦可以连套多少个区间,易得 d p i = max ⁡ j ∈ [ 1 , n ] j ! = i , a i < a j < b j < b i d p j + 1 dp_i=\max_{j\in[1,n]}^{j!=i,a_i<a_j<b_j<b_i} dp_j+1 dpi=maxj[1,n]j!=i,ai<aj<bj<bidpj+1,可以使用树状数组优化。

接下来有了 d p dp dp 后,易得答案为 max ⁡ i , j ∈ [ 1 , n ] i ! = j , b j < a i d p i + d p j \max_{i,j\in[1,n]}^{i!=j,b_j<a_i} dp_i+dp_j maxi,j[1,n]i!=j,bj<aidpi+dpj max ⁡ ( d p i ) \max(dp_i) max(dpi) 求最大值,前者也用树状数组优化即可,具体实现请参考代码。

代码:

#include <bits/stdc++.h>
using namespace std;
#define N 500010
int n,dp[N];
struct edg{int x,y;
}a[N];
bool cmp(edg a,edg b){return a.x>b.x; 
}
struct node{int c[N];void update(int id,int mx){while (id<=n*2){c[id]=max(c[id],mx); id+=(id&-id);}}int query(int id){int ans=0;while (id>0){ans=max(ans,c[id]); id-=(id&-id);}return ans;}
}tr,tr2;
int main(){ios::sync_with_stdio(0);cin.tie(0); cout.tie(0);cin>>n;for (int i=1; i<=n; i++){cin>>a[i].x>>a[i].y;if (a[i].x>a[i].y) swap(a[i].x,a[i].y);}sort(a+1,a+n+1,cmp);for (int i=1; i<=n; i++){dp[i]=tr.query(a[i].y)+1;tr.update(a[i].y,dp[i]);}for (int i=1; i<=n; i++){tr2.update(a[i].y,dp[i]);}int ans=0;for (int i=1; i<=n; i++){ans=max(ans,tr2.query(a[i].x)+dp[i]);}cout<<ans;
} 

二、后记

本篇题解结束了,祝愿大家能够在学习中实现一个一个小目标,在突破自我中成长。

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

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

相关文章

pyspark非安装使用graphframes

pyspark版本3.1.3 需要文件 graphframes-0.8.2-spark3.1-s_2.12.jarspark-graphx_2.12-3.1.3.jar从 https://github.com/microsoft/adb2spark/raw/main/graphframes-0.8.2-py3-none-any.whl 下载graphframes-0.8.2-py3-none-any.whl。下载后把whl后缀改成zip&#xff0c;解压…

[Linux入门] Linux磁盘管理与文件系统

目录 Linux磁盘与文件系统管理详解&#xff1a;从基础到实践 ​​一、磁盘基础简述​​ 1️⃣​​硬盘类型​​&#xff1a; ​2️⃣机械硬盘结构​​&#xff1a; 3️⃣​​磁盘容量计算​​&#xff1a; 公式&#xff1a;磁盘容量磁头数柱面数每磁道扇区数每扇区字节数 …

【Flutter】性能优化总结

【Flutter】性能优化总结 Flutter 性能优化是提升应用流畅度、响应速度和用户体验的关键。可以从以下几个方面进行优化&#xff1a; 一、UI 构建与布局优化 1、避免不必要的重建 使用 const 构造函数&#xff1a;如 const Text(Hello)&#xff0c;可以减少 Widget 重建。使用…

5、ZYNQ PL 点灯--流水灯

目录 1、 概述 2 、硬件电路 3、 新建 VIVADO 工程 4、 添加工程文件 6、编写流水灯功能的Verilog代码 7 、添加管脚约束文件 8、 RTL 仿真 8.1 添加仿真测试源码 8.2 仿真结果 9、 编译并且产生 bit 文件 10、 下载程序 11、实验结果 ​编辑12、总结 1、 概述 本…

HTML5 浮动

1. 常见网页布局 1-3-1布局 1-2-1布局 2. 标准文档流 3. display属性⭐ display&#xff1a; block 给span元素设置成block display&#xff1a; inline 给div元素设置成inline display&#xff1a; inline-block 给div和span元素设置为inline-block display&#xff1a; no…

若依使用RedisCache需要注意的事项

存入redis对象的时候会带一个type字段&#xff0c;此处需要注意 存入方&#xff1a; 此处需要注意&#xff0c;存入redis的时候会带一个type&#xff0c;也就是类的路径名 redisCache.setCacheObject(screenPlayQueueName, userDemondDto,userDemondDto.getPlayDuration().in…

【STM32的通用定时器CR1的CKD[1:0]: 时钟分频因子 (Clock division)】

在 STM32 的通用定时器&#xff08;如 TIM2, TIM3, TIM4, TIM5 等&#xff09;中&#xff0c;CR1 (Control Register 1) 寄存器中的 CKD[1:0] (Clock division) 位域是一个与抗干扰和数字滤波相关的设置&#xff0c;它并不直接影响定时器计数器 (CNT) 的计数频率&#xff08;计…

渲染学进阶内容——机械动力的渲染系统(2)

Flywheel代码 这篇来研究一下实例 InstanceHandle 接口深度解析 接口核心作用 InstanceHandle 是 Flywheel 渲染引擎中的 GPU实例句柄 接口,它提供了对底层渲染实例的直接控制能力。这个接口是**实例化渲染(Instanced Rendering)**系统的核心操作接口,与之前讨论的 Vis…

Redis:极速缓存与数据结构存储揭秘

Redis —— 这个强大又灵活的 开源、内存中的数据结构存储系统。它常被用作数据库、缓存、消息代理和流处理引擎。 核心特点 (为什么它这么受欢迎&#xff1f;)&#xff1a; 内存存储 (In-Memory): 数据主要存储在 RAM 中&#xff0c;读写操作直接在内存中进行。核心优势&…

vulnyx Diff3r3ntS3c writeup

信息收集 arp-scan nmap 这里默认的话是只有80端口的&#xff0c;这个22端口是我拿到root后开的 获取userFlag 直接上web看看 扫个目录 把网页拉到最下面可以看到一个文件上传点 我们尝试上传一个php文件 失败了&#xff0c;那xxx呢 上传成功了&#xff0c;看来后端的后缀名…

【构建】CMake 构建系统重点内容

CMake 构建系统重点内容 1 基本语法与结构 cmake_minimum_required() 指定使用的最低 CMake 版本&#xff0c;防止不同版本行为不一致&#xff1a; cmake_minimum_required(VERSION 3.16)project() 定义项目名称、语言和版本&#xff1a; project(MyApp VERSION 1.0 LANGU…

Packagerun:VSCode 扩展 快捷执行命令

Packagerun&#xff1a;VSCode 快捷命令扩展&#xff08;兼容cursor&#xff09; Packagerun 是一个为 前端和node开发者设计的 VSCode 扩展&#xff0c;旨在简化 package.json 中脚本的执行&#xff0c;并支持自定义命令以提升开发效率。通过右键菜单、快捷键或自定义配置&am…

【C语言】计算机组成、计算机语言介绍

1.1 计算机组成 1946年2月14日&#xff0c;由美国军方定制的世界上第一台电子计算机“电子数字积分计算机”( ENIAC Electronic Numerical And Calculator)在美国宾夕法尼亚大学问世。 计算机(俗称电脑)堪称是人类智慧的结晶&#xff0c;随着计算机的不断发展&#xff0c;各行各…

(九)山东大学软件学院项目实训-基于大模型的模拟面试系统-面试对话标题自动总结

面试对话标题自动总结 主要实现思路&#xff1a;每当AI回复用户之后&#xff0c;调用方法查看当前对话是否大于三条&#xff0c;如果大于则将用户的两条和AI回复的一条对话传给DeepSeek让其进行总结&#xff08;后端&#xff09;&#xff0c;总结后调用updateChatTopic进行更新…

降阶法求解偏微分方程

求解给定的四个偏微分方程,采用降阶法,令 v = u x v = u_x v=ux​,从而将原方程转化为关于 v v v 的一阶方程。 方程 u x y = 0 u_{xy} = 0 uxy​=0 令 v = u x v = u_x v=ux​,则方程变为 v y = 0 v_y = 0 vy​=0。解得 v = C 1 ( x ) v = C_1(x) v=C1​(x),即 u …

提的缺陷开发不改,测试该怎么办?

经历长时间的细致检查&#xff0c;逐条执行数十条测试用例&#xff0c;终于发现一处疑似缺陷。截图留存、粘贴日志&#xff0c;认真整理好各项信息&#xff0c;将它提交到缺陷管理系统。可不到五分钟&#xff0c;这条缺陷就被打回了。开发人员给出的回复十分简洁&#xff1a;“…

【Flutter】Widget、Element和Render的关系-Flutter三棵树

【Flutter】Widget、Element和Render的关系-Flutter三棵树 一、前言 在 Flutter 中&#xff0c;所谓的“三棵树”是指&#xff1a; Widget Tree&#xff08;部件树&#xff09;Element Tree&#xff08;元素树&#xff09;Render Tree&#xff08;渲染树&#xff09; 它们是…

IO之详解cin(c++IO关键理解)

目录 cin原理介绍 控制符(hex、oct、dec) cin如何检查输入 cin与字符串 cin.get(char ch) cin.get(void) istream &get(char*,int) istream &get(char*,int,char) istream &getline(char*,int); 遇到文件结尾EOF 无法完成一次完整输入&#xff1a;设置f…

Bootstrap 5学习教程,从入门到精通, Bootstrap 5 分页(Pagination)知识点及案例代码(13)

Bootstrap 5 分页&#xff08;Pagination&#xff09;知识点及案例代码 Bootstrap 5 提供了强大的分页组件&#xff0c;帮助开发者轻松实现分页功能。以下是关于 Bootstrap 5 分页的详细语法知识点以及一个完整的案例代码&#xff0c;包含详细注释&#xff0c;帮助初学者快速上…

Dina靶机渗透

1.信息查询 1.1. Ip查询 arp-scan -l 192.168.220.137 1.2. 端口收集 nmap -T4 -A -p- 192.168.220.137 1.3. 目录扫描 dirsearch -u 192.168.220.137 -e* -i 200 通过访问 robots.txt 文件发现有些禁止访问得目录 User-agent: *Disallow: /ange1Disallow: /angel1Dis…