预处理出每个原子最近的不能合并的位置

枚举当前位置和前面断开的位置合并

发现还是不能过

考虑用选段树优化

但是因为每次转移的最优点是在前面可以合并的范围内 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 【原子】的更多相关文章

  1. 【简】题解 AWSL090429 【市场】

    因为这有个时间的限制 并且  求的时间都是前缀和 那么 我们可以根据时间将排序 因为题中没有修改可以直接用背包预处理出答案 但是因为题目ci mi<=1e9   vi<=300 所以发现不 ...

  2. 【简】题解 AWSL090429 【噪音】

    因为每次加上一头奶牛 是什么不重要 牛棚之间贡献除清空操作外无影响 就只要考虑 每个牛棚清空分x次 的贡献 x之和为k       求贡献和最小 一个牛棚清空x次 显然平均清空贡献最小 再用等差数列的 ...

  3. 【简】题解 AWSL090429 【数塔问题】

    因为每次只ban一个点 而且不是永久性的 预处理出每个点从上往下和从下往上的最大值 每次询问直接暴力 被ban掉点那行去掉那点的最大值 也可以直接预处理出每行的最大值和次大值 还有种做法貌似可以过 预 ...

  4. 【简】题解 AWSL090429 【聚会】

    这题直接换根dp 记录在要转移的点的子树中有多少牛 #include<bits/stdc++.h> using namespace std; #define ll long long #d ...

  5. 【简】题解 AWSL090429 【价值】

    先考虑当要选的物品一定时 显然有个贪心 wi越小的要越先选 所以先按wi从小到大拍序 因为发现正着递推要记录的状态很多 并且wi的贡献与后面选了几个物品有关 考虑正难则反 倒着递推 提前计算wi的贡献 ...

  6. DP笔记

    这是一篇蒟蒻被大佬踩爆后写的笔记 套路 0.贪心(废话)(排序...) 1.dp预处理出要用的东西 2.两头同时dp 3.化简题目中本质相同的东西 转化模型 4.数学计算优化 5.分析题目数据考虑该从 ...

  7. 【简】题解 P5283 [十二省联考2019]异或粽子

    传送门:P5283 [十二省联考2019]异或粽子 题目大意: 给一个长度为n的数列,找到异或和为前k大的区间,并求出这些区间的异或和的代数和. QWQ: 考试时想到了前缀异或 想到了对每个数按二进制 ...

  8. 【简】题解 P4297 [NOI2006]网络收费

    传送门:P4297 [NOI2006]网络收费 题目大意: 给定一棵满二叉树,每个叶节点有一个状态(0,1),任选两个叶节点,如果这两个叶节点状态相同但他们的LCA所管辖的子树中的与他们状态相同的叶节 ...

  9. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

随机推荐

  1. GitHub 12个实用技巧-从projiect项目管理、代码链接到博客wiki全过程

    1 在GitHub.com上编辑代码 2 粘贴图片 3 美化代码 4 在PRs中巧妙关闭issues 5 链接到评论 6 链接到代码 7 灵活使用GitHub地址栏 8 创建复选框列表 9 在GitH ...

  2. [atARC096F]Sweet Alchemy

    给定一棵有根树,记$f_{i}$表示$i$的父亲,每一个点有一个代价$c_{i}$ 给定常数$D$和$X$,再给每个点赋一个权值$v_{i}$($v_{i}\ge 0$),满足以下条件下最大化$\su ...

  3. 【HTML】基础

    HTML基础 2019-07-23  10:16:28  by冲冲 在线编辑HTML/CSS/JS效果,实时查看效果 https://c.runoob.com/front-end/61 1. 概念 ① ...

  4. 解决fatal: unable to access '': Failed to connect to 127.0.0.1 port 1181: Connection refused的问题

    今天把项目提交的git远程的时候遇到一个问题 fatal: unable to access '': Failed to connect to 127.0.0.1 port 1181: Connect ...

  5. jmeter中执行kafka topic指令

    前置条件 kafka版本:2.2.1 jmeter版本:5.3 插件:ApacheJMeter_ssh-1.2.0.jar 1.拷贝 ApacheJMeter_ssh-1.2.0.jar 到/lib/ ...

  6. 面渣逆袭:HashMap追魂二十三问

    大家好,我是老三. HashMap作为我们熟悉的一种集合,可以说是面试必考题.简单的使用,再到原理.数据结构,还可以延伸到并发,可以说,就一个HashMap,能聊半个小时. 1.能说一下HashMap ...

  7. Atcoder Regular Contest 072 C - Alice in linear land(思维题)

    Atcoder 题面传送门 & 洛谷题面传送门 首先求出 \(s_i\) 表示经过 \(i\) 次操作后机器人会位于什么位置,显然 \(s_0=D\),\(s_i=\min(s_{i-1},| ...

  8. 洛谷 P4709 - 信息传递(置换+dp)

    题面传送门 一道挺有意思的题罢-- 首先看到这种与置换乘法相关的题,首先把这些置换拆成一个个置换环,假设输入的置换有 \(m\) 个置换环,大小分别为 \(s_1,s_2,\cdots,s_m\),显 ...

  9. 金蝶EAS——客户端打开时,提示正在更新的文件d:\eas\client\bin\lib\proxy.jar被其他应用程序占用.请关闭

    解决办法: 一.通过调用任务管理器来退出,启用任务管理器需同时按下键Ctrl+Alt+Del,在应用程序中找到金蝶EAS,单击,选择结束任务即可:或者在任务管理器中选择"进程",点 ...

  10. Demo04分解质因数

    package 习题集1;import java.util.Scanner;//将一个正整数分解质因数.例如输入90,打印出90=2*3*3*5public class Demo04 { public ...