【简】题解 AWSL090429 【原子】

预处理出每个原子最近的不能合并的位置
枚举当前位置和前面断开的位置合并
发现还是不能过
考虑用选段树优化
但是因为每次转移的最优点是在前面可以合并的范围内 dp值加上当前的到该点的最大值
因为每个位置的最大值每次更新不是只更新一个位置
是一次更新一段位置
所以直接维护复杂度爆炸
有种方法(套路) 是把最值的更新改为值的加减
因为每次是更新一段区间
且每个点到当前的位置的最值是单调不减的
所以每次的修改就可以是一段一段的
可以用单调栈来维护每种值的区间
就可以进行区间修改
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define C getchar()-48
inline ll read()
{
ll s=0,r=1;
char c=C;
for(;c<0||c>9;c=C) if(c==-3) r=-1;
for(;c>=0&&c<=9;c=C) s=(s<<3)+(s<<1)+c;
return s*r;
}
const int N=1e5+10,inf=1e9;
int n,qm;
int p[N],v[N],q[N];
int vis[N];
int dp[N];
int dv[N],dr[N],top;
struct xin{
int del,mn;
}tr[N<<2];
inline void up(int x)
{
tr[x].mn=min(tr[x<<1].mn,tr[x<<1|1].mn)+tr[x].del;
}
inline void down(int x)
{
tr[x<<1].del=tr[x<<1|1].del=tr[x].del;
tr[x].del=0;
}
inline void add(int x,int l,int r,int ql,int qr, int v)
{
if(ql<=l&&r<=qr){tr[x].del+=v,tr[x].mn+=v;return;}
int mid=(l+r)>>1;
if(ql<=mid) add(x<<1,l,mid,ql,qr,v);
if(mid<qr) add(x<<1|1,mid+1,r,ql,qr,v);
up(x);
}
inline int ask(int x,int l,int r,int ql,int qr)
{
if(ql<=l&&r<=qr){return tr[x].mn;}
int mid=(l+r)>>1,mn=inf;
if(ql<=mid) mn=min(mn,ask(x<<1,l,mid,ql,qr));
if(mid<qr) mn=min(mn,ask(x<<1|1,mid+1,r,ql,qr));
up(x);
return mn+tr[x].del;
}
int main()
{
freopen("array.in","r",stdin);
freopen("array.out","w",stdout);
n=read();qm=n;vis[0]=1;dv[0]=inf;dr[0]=0;
for(int i=1;i<=n;i++) p[i]=read(),v[i]=read();
for(int i=n;i>=1;i--)
{
while(!vis[p[qm]]){vis[p[qm]]=1;qm--;}
q[i]=qm;
vis[p[i]]=0;
}
for(int i=1;i<=n;i++)
{
add(1,1,n,i,i,v[i]);
while(dv[top]<v[i])
{
add(1,1,n,dr[top-1]+1,dr[top],v[i]-dv[top]);
top--;
}
dv[++top]=v[i],dr[top]=i;
dp[i]=ask(1,1,n,q[i]+1,i);
add(1,1,n,i+1,i+1,dp[i]);
}
cout<<dp[n];
return 0;
}
还有位大佬用multiset维护
#include<bits/stdc++.h>
using namespace std; #define Abigail inline void
typedef long long LL; const int N=100000,INF=(1<<30)-1; multiset<int>t;
int n,a[N+9],b[N+9],data[N+9],last[N+9],l[N+9];
int sum[N+9],wei[N+9],f[N+9],hd,tl; Abigail into(){
scanf("%d",&n);
for (int i=1;i<=n;++i)
scanf("%d%d",&a[i],&b[i]);
} Abigail work(){
for (int i=1;i<=n;++i)
l[i]=max(l[i-1],last[a[i]]+1),last[a[i]]=i;
//预处理每一个位置为结尾可以取的转移的区间左端点
hd=1;
int k;
for (int i=1;i<=n;++i){
k=i-1;
for (;hd<tl&&wei[hd+1]<l[i];++hd)
t.erase(t.find(sum[hd]));
//把不在转移区间的位置去掉
for (;hd<=tl&&b[i]>data[tl];--tl)
t.erase(t.find(sum[tl])),k=wei[tl];
//更新阶梯型(max{b[j]..b[i]})
data[++tl]=b[i];
wei[tl]=k;
//加入第i个位置
if (hd^tl){
sum[tl]=f[wei[tl]]+data[tl];
//把位置i所在的阶梯中最优的值sum[tl]计算出来
t.insert(sum[tl]);
//加入set中
t.erase(t.find(sum[hd]));
//开头的那一段阶梯中会有一部分不可取,一部分可取
}
sum[hd]=f[l[i]-1]+data[hd];
//采取开头最优的那段
t.insert(sum[hd]);
//加入set中
f[i]=*t.begin();
}
} Abigail outo(){
printf("%d\n",f[n]);
} int main(){
freopen("array.in","r",stdin);
freopen("array.out","w",stdout);
into();
work();
outo();
return 0;
}
【简】题解 AWSL090429 【原子】的更多相关文章
- 【简】题解 AWSL090429 【市场】
因为这有个时间的限制 并且 求的时间都是前缀和 那么 我们可以根据时间将排序 因为题中没有修改可以直接用背包预处理出答案 但是因为题目ci mi<=1e9 vi<=300 所以发现不 ...
- 【简】题解 AWSL090429 【噪音】
因为每次加上一头奶牛 是什么不重要 牛棚之间贡献除清空操作外无影响 就只要考虑 每个牛棚清空分x次 的贡献 x之和为k 求贡献和最小 一个牛棚清空x次 显然平均清空贡献最小 再用等差数列的 ...
- 【简】题解 AWSL090429 【数塔问题】
因为每次只ban一个点 而且不是永久性的 预处理出每个点从上往下和从下往上的最大值 每次询问直接暴力 被ban掉点那行去掉那点的最大值 也可以直接预处理出每行的最大值和次大值 还有种做法貌似可以过 预 ...
- 【简】题解 AWSL090429 【聚会】
这题直接换根dp 记录在要转移的点的子树中有多少牛 #include<bits/stdc++.h> using namespace std; #define ll long long #d ...
- 【简】题解 AWSL090429 【价值】
先考虑当要选的物品一定时 显然有个贪心 wi越小的要越先选 所以先按wi从小到大拍序 因为发现正着递推要记录的状态很多 并且wi的贡献与后面选了几个物品有关 考虑正难则反 倒着递推 提前计算wi的贡献 ...
- DP笔记
这是一篇蒟蒻被大佬踩爆后写的笔记 套路 0.贪心(废话)(排序...) 1.dp预处理出要用的东西 2.两头同时dp 3.化简题目中本质相同的东西 转化模型 4.数学计算优化 5.分析题目数据考虑该从 ...
- 【简】题解 P5283 [十二省联考2019]异或粽子
传送门:P5283 [十二省联考2019]异或粽子 题目大意: 给一个长度为n的数列,找到异或和为前k大的区间,并求出这些区间的异或和的代数和. QWQ: 考试时想到了前缀异或 想到了对每个数按二进制 ...
- 【简】题解 P4297 [NOI2006]网络收费
传送门:P4297 [NOI2006]网络收费 题目大意: 给定一棵满二叉树,每个叶节点有一个状态(0,1),任选两个叶节点,如果这两个叶节点状态相同但他们的LCA所管辖的子树中的与他们状态相同的叶节 ...
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
随机推荐
- 我罗斯方块第二次作业(Player类)
我罗斯方块第二次作业 我的任务 完成player类的编写 player类的测试 我的计划 类的设计: Player类作为一个玩家类,需要处理和玩家有关的所有信息,以及维护玩家的游戏页面map.关于玩家 ...
- 博主日常工作中使用的shell脚本分享
前言: 今天给大家分享一篇在我工作中常用的一个shell脚本,里面有一些我们常用到的shell操作.该脚本用于本地电脑和服务器交互上,实现以下功能: 自动拉取自己个人电脑上的源码到服务器上yocto包 ...
- Python基础(@property)
class Point(object): # def get_score(self): # return self.score # def set_score(self,value): # if no ...
- jenkins安装与配置---window,mis包直接安装
https://my.oschina.net/aibinxiao/blog/1457218 Jenkins在Windows下的安装与配置 已经在https://jenkins.io/下载好了Win ...
- 填坑总结:python内存泄漏排查小技巧
摘要:最近服务遇到了内存泄漏问题,运维同学紧急呼叫解决,于是在解决问题之余也系统记录了下内存泄漏问题的常见解决思路. 本文分享自华为云社区<python内存泄漏排查小技巧>,作者:luti ...
- idea内存配置
找到IDEA安装的bin目录 打开idea.exe.vmoptions 文件 如果嫌麻烦还打开了idea 那么就可以点击这个.. 关键的三个参数的说明 1. -Xms 是最小启动内存参数 2. -X ...
- setoolkit的钓鱼实验
1.在kali中打开setoolkit 2.在菜单中选择第一个进入社会工程学攻击 3.选择第二个模块属于网站攻击向量 4.选择第五个模块,进行web劫持攻击 5.选择第二个,进行网站克隆 6.发现访问 ...
- HDU 6116 路径计数
HDU 6116 路径计数 普通生成函数常用于处理组合问题,指数生成函数常用于处理排列问题. 考虑 对于 $ a $ 个 $ A $ 分为很多堆,这么分的方案数是 $ C_{a-1}^{i-1} $ ...
- Spring-boot -Web开发
1).创建SpringBoot应用,选中我们需要的模块: 2).SpringBoot已经默认将这些场景配置好了,只需要在配置文件中指定少量配置就可以运行起来 3).自己编写业务代码: 文件名的功能 x ...
- Linux—Linux系统目录结构
登录系统后,在当前命令窗口下输入命令: ls / 你会看到如下图所示: 树状目录结构: 以下是对这些目录的解释: /bin:bin是Binary的缩写, 这个目录存放着最经常使用的命令. /boo ...