news 2026/4/16 9:01:25

题解:AT_abc436_f

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
题解:AT_abc436_f

题面

Starry Landscape Photo

问题描述

AtCoder行星上看到的夜空中,有N NN颗星星,这些星星从东到西排成一条直线。从东方数起的第i ii颗星(1 ≤ i ≤ N 1 \le i \le N1iN)是这些星星中第B i B _ iBi亮的。

Takahashi决定按照以下步骤拍摄夜空的照片:

1.选择一对整数(l , r l , rl,r),满足1 ≤ l ≤ r ≤ N 1 \le l \le r \le N1lrN,并设置相机,使得从东数起的第l ll、第l + 1 l + 1l+1… \dots、第r rr颗星都能进入画面,而其他星星不会进入画面。

2.选择一个整数b bb,满足1 ≤ b ≤ N 1 \le b \le N1bN,打开快门,使得所有亮度排名在第1 11到第b bb位之间(且位于画面中的)星星被捕捉,而其他星星不会被捕捉。

但是,他不能拍摄不包含任何星星的照片。

求出在这种方式下拍摄的照片中,可以捕捉到的不同星星集合的数量。

约束条件

1 ≤ N ≤ 5 × 1 0 5 1 \le N \le 5 \times 10 ^ 51N5×105

1 ≤ B i ≤ N 1 \le B _ i \le N1BiN1 ≤ i ≤ N 1 \le i \le N1iN

B i ≠ B j B _ i \neq B _ jBi=Bj1 ≤ i < j ≤ N 1 \le i < j \le N1i<jN

所有输入值都是整数。

输入

输入通过标准输入给出,格式如下:

N NN
B 1 B 2 … B N B _ 1 \ B _ 2 \ \dots \ B _ NB1B2BN

输出

输出答案。

思路

tag \text{tag}tag数学树状数组

根据题意,易知一张照片由左端点、右端点与感光度(照片中最暗亮度值)决定。令pos i \text{pos} _ iposi为亮度为i ii的星星的位置,则满足i ∈ [ 1 , N ] i \in [1 , N]i[1,N]的三元数对( l , r , pos i ) (l , r , \text{pos} _ i)(l,r,posi),其l llr rr取值分别有L i L _ iLiR i R _ iRi种,其中L i L _ iLi为同时满足j ≤ pos i j \le \text{pos} _ ijposiB j ≤ i B _ j \le iBjij jj的个数,R i R _ iRi为同时满足j ≥ pos i j \ge \text{pos} _ ijposiB j ≤ i B _ j \le iBjij jj的个数。根据乘法原理,照片种数为左端点个数与右端点个数的乘积,又因满足B j < i B _ j < iBj<ij jj的个数为i + 1 i + 1i+1个,故ans = ∑ i = 1 N L i R i = ∑ i = 1 N L i ( i + 1 − L i ) \text{ans} = \sum _ {i = 1} ^ {N} L _ i R _ i = \sum _ {i = 1} ^ {N} L _ i (i + 1 - L _ i)ans=i=1NLiRi=i=1NLi(i+1Li)

由于1 ≤ N ≤ 5 × 1 0 5 1 \le N \le 5 \times 10 ^ 51N5×105,所以需在O ( log ⁡ 2 N ) O(\log _ 2 N)O(log2N)时间内求出每个i iiL i L _ iLi。考虑用树状数组。令i ii为升序,则每次计算时,在pos i \text{pos} _ iposi处增加一个星星,并计算位置小于等于pos i \text{pos} _ iposi的个数,即L i L _ iLi

预处理pos \text{pos}pos需要O ( N ) O(N)O(N),树状数组O ( N log ⁡ 2 N ) O(N \log _ 2 N)O(Nlog2N),总时间复杂度O ( N log ⁡ 2 N ) O(N \log _ 2 N)O(Nlog2N)

代码

#include<bits/stdc++.h>#defineintlonglongusingnamespacestd;constintmaxn=5e5;intb[maxn+5];intpos[maxn+5];intk[maxn*2+5];intn;intans=0;intlowbit(intx){returnx&(-x);}voidadd(intx){for(;x<=maxn*2;x+=lowbit(x)){k[x]++;}}intquery(intx){intres=0;for(;x;x-=lowbit(x)){res+=k[x];}returnres;}voidsolve(){cin>>n;for(inti=1;i<=n;i++){cin>>b[i];pos[b[i]]=i;}for(inti=1;i<=n;i++){add(pos[i]);inttmp=query(pos[i]);ans+=tmp*(i-tmp+1);}cout<<ans<<"\n";}signedmain(){intt=1;while(t--){solve();}return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 22:20:19

每天一个网络知识:什么是堆叠?

在企业网络、数据中心或学校机房中&#xff0c;我们常常会看到多个交换机整齐排列在机柜里。随着网络规模增加&#xff0c;设备数量越来越多&#xff0c;如何让这些交换机更高效地协同工作、简化管理、提高可靠性&#xff1f; 其中一个非常重要的技术就是 “堆叠&#xff08;S…

作者头像 李华
网站建设 2026/4/16 1:42:56

Django WiFi文件分享

项目介绍 在日常工作和生活中,我们经常需要在电脑和手机之间传输文件。传统的传输方式要么需要数据线连接,要么需要借助第三方应用,操作繁琐且不够高效。今天,我将介绍一个基于Django开发的WiFi文件分享应用,它可以让你通过电脑选择本地文件夹,生成访问二维码,然后通过…

作者头像 李华
网站建设 2026/4/16 1:40:56

《高压电气连接器必备指南》

高压电气连接器对于工作电压超过 60V 的电路以及汽车和工业应用中的关键组件至关重要。它们促进大电流的传输——特别是在电动汽车中——连接电池组、电机控制器和充电器等关键部件。高压电气连接器中使用的材料以下是在高压连接器开发和使用中常用的关键材料&#xff1a;导电材…

作者头像 李华
网站建设 2026/4/14 5:43:12

springboot月度员工绩效考核管理系统(11488)

有需要的同学&#xff0c;源代码和配套文档领取&#xff0c;加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码&#xff08;前后端源代码SQL脚本&#xff09;配套文档&#xff08;LWPPT开题报告&#xff09;远程调试控屏包运行 三、技术介绍 Java…

作者头像 李华
网站建设 2026/4/7 13:21:52

mysql中的索引页是什么?

1.索引页是存储b树索引结构的页&#xff0c;存储索引数据&#xff0c;默认大小为16kb 2.叶子节点&#xff0c;如果是主键索引(聚簇索引)&#xff0c;存储完整行数据&#xff0c;如果是二级索引,存储索引键值主键值 3.叶子节点通过双向链表连接&#xff0c;支持范围查询 4.非叶子…

作者头像 李华
网站建设 2026/4/8 5:58:17

第14章:项目沟通管理【章节重点】

信息系统项目管理师第14章&#xff1a;项目沟通管理【章节重点】。重点章节&#xff1a;不论是单选、案例分析都有考点&#xff0c;论文考的并不多&#xff0c;从&#xff1a;沟通概念、沟通模型(P421&#xff09;、沟通分类、沟通技巧、项目沟通管理&#xff0c;本视频由科科过…

作者头像 李华