LINK:T1



算是一道中档题 考试的时候脑残了 不仅没写优化 连暴力都打挂了。

容易发现一个性质 那就是同一格子不会被两种以上的颜色染。(颜色就三种.

通过这个性质就可以进行dp了.先按照左端点排序。

设f[i]表示前i个画笔必选的最大价值。

枚举决策j 分类讨论相交还是包含 还是相离。

其中包含的情况没必要讨论 相交需要比对一下颜色再进行转移 不过我写的时候多打一个东西导致爆零.

值得一提的是 对于相交的情况 相交的部分不会被之前转移的线段给交上去 可以证明这样不是最优的。

所以这样dp是正确的。

code:

const int MAXN=100010;
int n,m,s1,s2,flag;
ll ans,f[MAXN];
struct wy{int x,y,c;}t[MAXN];
inline int cmp(wy a,wy b){return a.x<b.x;}
int main()
{
freopen("T1.in","r",stdin);
freopen("T1.out","w",stdout);
get(n);get(m);get(s1);get(s2);
rep(1,m,i)
{
int get(c),get(x),get(y);
t[i]=(wy){x,y,c};
if(!flag)flag=c;
else if(flag!=c)flag=INF;
}
sort(t+1,t+1+m,cmp);
if(flag!=INF)
{
ll ans=0;int mx=0;
rep(1,m,i)
{
if(mx>=t[i].y)continue;
if(t[i].x<mx)ans+=((ll)t[i].y-mx)*s1;
else ans+=(ll)((ll)t[i].y-t[i].x+1)*s1;
mx=t[i].y;
}
putl(ans);
return 0;
}
//putl(ans);
if(m<=1000)
{
rep(1,m,i)
{
rep(0,i-1,j)
{
if(t[i].y<=t[j].y)continue;
if(t[i].x>t[j].y)
{
f[i]=max(f[i],f[j]+((ll)t[i].y-t[i].x+1)*s1);
continue;
}
int ww=(t[i].c!=t[j].c);
f[i]=max(f[i],f[j]+((ll)t[i].y-t[j].y)*s1-((ll)t[j].y-t[i].x+1)*ww*(s1+s2));
}
ans=max(ans,f[i]);
}
putl(ans);return 0;
}
return 0;
}

考虑正解。其实正解很好想 不过我没胆子写。

容易 发现可以分类讨论。对于相离的情况 写一个线段树 在右端点放值 查询查左端点-1即可。

对于相交的情况 还是分类讨论 考虑如果是同颜色的话查 还是右端点放值 区间内查 放值的具体形式展开上述的dp式即可。

对于不同颜色相交 同样展开上述dp式 在线段树里做即可。

第一种情况需要一颗线段树 第二种情况需要三颗线段树 第三种情况同样需要三种 简单的做法是 三种不同颜色各自维护相交的情况。

由于所有的线段树维护的东西相同 所以可以使用指针做这件事情 也可以使用结构体。

const int MAXN=100010;
int n,m,top;ll s1,s2;
int b[MAXN<<1];
struct wy{int x,y,c;}t[MAXN];
inline int cmp(wy a,wy b){return a.x<b.x;}
struct jl
{
ll s[MAXN<<3];
inline void cle(){memset(s,0xcf,sizeof(s));}
inline void change(int p,int l,int r,int w,ll x)
{
if(l==r){s[p]=max(s[p],x);return;}
int mid=(l+r)>>1;
if(w<=mid)change(zz,l,mid,w,x);
else change(yy,mid+1,r,w,x);
s[p]=max(s[zz],s[yy]);
}
ll ask(int p,int l,int r,int L,int R)
{
if(L<=l&&R>=r)return s[p];
int mid=(l+r)>>1;
if(R<=mid)return ask(zz,l,mid,L,R);
if(L>mid)return ask(yy,mid+1,r,L,R);
return max(ask(zz,l,mid,L,R),ask(yy,mid+1,r,L,R));
}
}f[3],g[3],s;
int main()
{
freopen("1.in","r",stdin);
//freopen("T1.out","w",stdout);
get(n);get(m);get(s1);get(s2);
rep(1,m,i)
{
int get(c),get(x),get(y);
t[i]=(wy){x,y,c-1};
b[++top]=x;b[++top]=y;
}
sort(b+1,b+1+top);
int num=0;
rep(1,top,i)if(i==1||b[i]!=b[i-1])b[++num]=b[i];
rep(1,m,i)
{
t[i].x=lower_bound(b+1,b+1+num,t[i].x)-b;
t[i].y=lower_bound(b+1,b+1+num,t[i].y)-b;
}
sort(t+1,t+1+m,cmp);
s.cle();
rep(0,2,i)f[i].cle(),g[i].cle();
s.change(1,0,num,0,0);
rep(1,m,i)
{
ll ww=s.ask(1,0,num,0,t[i].x-1)+(b[t[i].y]-b[t[i].x]+1)*s1;
rep(0,2,j)
{
if(t[i].c==j)//同色转移用f
ww=max(ww,f[j].ask(1,0,num,t[i].x,t[i].y)+b[t[i].y]*s1);
else //不同色用g
ww=max(ww,g[j].ask(1,0,num,t[i].x,t[i].y)+b[t[i].x]*(s1+s2)-s1-s2+b[t[i].y]*s1);
}
s.change(1,0,num,t[i].y,ww);
f[t[i].c].change(1,0,num,t[i].y,ww-b[t[i].y]*s1);
g[t[i].c].change(1,0,num,t[i].y,ww-b[t[i].y]*(s1+s1+s2));
}
putl(s.s[1]);
return 0;
}

省选模拟赛 4.26 T1 dp 线段树优化dp的更多相关文章

  1. 省选模拟赛 Problem 3. count (矩阵快速幂优化DP)

    Discription DarrellDarrellDarrell 在思考一道计算题. 给你一个尺寸为 1×N1 × N1×N 的长条,你可以在上面切很多刀,要求竖直地切并且且完后每块的长度都是整数. ...

  2. 4.11 省选模拟赛 序列 二分 线段树优化dp set优化dp 缩点

    容易想到二分. 看到第一个条件容易想到缩点. 第二个条件自然是分段 然后让总和最小 容易想到dp. 缩点为先:我是采用了取了一个前缀最小值数组 二分+并查集缩点 当然也是可以直接采用 其他的奇奇怪怪的 ...

  3. [AGC011F] Train Service Planning [线段树优化dp+思维]

    思路 模意义 这题真tm有意思 我上下楼梯了半天做出来的qwq 首先,考虑到每K分钟有一辆车,那么可以把所有的操作都放到模$K$意义下进行 这时,我们只需要考虑两边的两辆车就好了. 定义一些称呼: 上 ...

  4. 洛谷$P2605\ [ZJOI2010]$基站选址 线段树优化$dp$

    正解:线段树优化$dp$ 解题报告: 传送门$QwQ$ 难受阿,,,本来想做考试题的,我还造了个精妙无比的题面,然后今天讲$dp$的时候被讲到了$kk$ 先考虑暴力$dp$?就设$f_{i,j}$表示 ...

  5. Codeforces Round #426 (Div. 2) D 线段树优化dp

    D. The Bakery time limit per test 2.5 seconds memory limit per test 256 megabytes input standard inp ...

  6. BZOJ2090: [Poi2010]Monotonicity 2【线段树优化DP】

    BZOJ2090: [Poi2010]Monotonicity 2[线段树优化DP] Description 给出N个正整数a[1..N],再给出K个关系符号(>.<或=)s[1..k]. ...

  7. zoj 3349 dp + 线段树优化

    题目:给出一个序列,找出一个最长的子序列,相邻的两个数的差在d以内. /* 线段树优化dp dp[i]表示前i个数的最长为多少,则dp[i]=max(dp[j]+1) abs(a[i]-a[j])&l ...

  8. 【bzoj3939】[Usaco2015 Feb]Cow Hopscotch 动态开点线段树优化dp

    题目描述 Just like humans enjoy playing the game of Hopscotch, Farmer John's cows have invented a varian ...

  9. POJ 2376 Cleaning Shifts (线段树优化DP)

    题目大意:给你很多条线段,开头结尾是$[l,r]$,让你覆盖整个区间$[1,T]$,求最少的线段数 题目传送门 线段树优化$DP$裸题.. 先去掉所有能被其他线段包含的线段,这种线段一定不在最优解里 ...

随机推荐

  1. css3-pointer-events

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  2. JAVA的8种基本数据类型分析

    基本数据类型(8个) 1.整数类型(4个)   字节个数 取值范围 byte(字节) 1(8位) -2^7~2^7-1 short(短整型) 2(16位) -2^15~2^15-1 int(整形) 4 ...

  3. 解决安装mysql 提示msvcr100.dill 丢失,的最快方法

    我也是在学习mysql的时候遇到的这个问题,很多人也遇到了,于是在百度找解决方案 看到有人论坛中写道,用 360安全卫士,可以修复于是我下载了360安全卫士尝试修复, 在人工解答中搜索dll修复,也修 ...

  4. 使用@AutoConfigureBefore调整配置顺序竟没生效?

    一个人的价值体现在能够帮助多少人.自己编码好,价值能得到很好的体现.若你做出来的东西能够帮助别人开发,大大减少开发的时间,那就功德无量. 作者:A哥(YourBatman) 公众号:BAT的乌托邦(I ...

  5. Jmeter系列(33)- 跨平台运行 Jmeter,CSV 文件路径如何设置?

    如果你想从头学习Jmeter,可以看看这个系列的文章哦 https://www.cnblogs.com/poloyy/category/1746599.html 抛出问题 上一篇文章中详细讲解了 CS ...

  6. WPF DataGrid ScrollBar Style

    效果图如下 代码 <DataGrid.Resources> <Style TargetType="{x:Type ScrollBar}"> <Sett ...

  7. sqlilabs 1-20关 payload

    1.联合查询注入:http://127.0.0.1/sqli/Less-1/?id=-1' union select 1,user(),3 --+http://127.0.0.1/sqli/Less- ...

  8. keepalived 热备

    概述 keepalived高可用集群      keepalived最初是为了LVS的,因为LVS无法进行自动检测服务器的节点状态(可以自动部署LVS)     keeplived后来加入VRRP给功 ...

  9. 2-ADC

  10. scrapy 基础组件专题(四):信号运用

    一.scrapy信号使用的简单实例 import scrapy from scrapy import signals from ccidcom.items import CcidcomItem cla ...