【简】题解 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. 树链剖分数据结构板题 题目大意:我 ...
随机推荐
- C# 判断未将对象引用设置到对象的实例,出错的代码到底在第几行
DataTable dt = null; try { var x = dt.Rows.Count; } catch(NullReferenceException nullexception) { Me ...
- spring boot+vue实现H5聊天室客服功能
spring boot+vue实现H5聊天室客服功能 h5效果图 vue效果图 功能实现 spring boot + webSocket 实现 官方地址 https://docs.spring.io/ ...
- 在Jenkins中执行 PowerShell 命令实现高效的CD/CI部署
相比于cmd,powershell支持插件.语法扩展和自定义扩展名,是智能化部署中闪闪的新星,越来越多的开发者偏爱使用Powershell. 如何让Jenkins支持Powershell呢?本文即展开 ...
- React-Router示例(重定向与withRouter)
1.withRouter作用:把不是通过路由切换过来的组件中,将react-router 的 history.location.match 三个对象传入props对象上 默认情况下必须是经过路由匹 ...
- 100_第一个vue-cli项目
目录 什么是vue-cli 主要的功能 需要的环境 Node.js : http://nodejs.cn/download/ Git : https://git-scm.com/downloads 安 ...
- go程序不停机重启
让我们给http服务写一个版本更新接口,让它自动更新版本并重启服务吧. 初步例子 注:为了精简,文中代码都去除了err处理 main.go var Version = "1.0" ...
- mybatis新增账号并且返回主键id
<!--新增账号和权限的关联关系--><insert id="save" useGeneratedKeys="true" keyPropert ...
- P6604 [HNOI2016]序列 加强版
*I. P6604 [HNOI2016]序列 加强版 摘自学习笔记 简单树论 笛卡尔树部分例题 I. 和 P6503 比较类似.我们设 \(f_i\) 表示全局以 \(i\) 结尾的子区间的最小值之和 ...
- DirectX12 3D 游戏开发与实战第六章内容
利用Direct3D绘制几何体 学习目标 探索用于定义.存储和绘制几何体数据的Direct接口和方法 学习编写简单的顶点着色器和像素着色器 了解如何用渲染流水线状态对象来配置渲染流水线 理解怎样创建常 ...
- 短序列组装Sequence Assembly(转载)
转载:http://blog.sina.com.cn/s/blog_4af3f0d20100fq5i.html 短序列组装(Sequence assembly)几乎是近年来next-generatio ...