interlinkage:

https://jzoj.net/senior/#main/show/6073

description:

solution:

  • 考虑一条河$x$被染的效果
  • 显然对于一条河$i$来说,若$k_i>k_x,b_i<b_x$,那么$i$会被$x$直接染
  • 这实际上启示我们可以把直线按$k$为第一关键字,$b$为第二关键字升序排序
  • 又发现若$k_i>k_x,b_i>b_x$,这条河会被$x$染色的充要条件是存在$k_y>k_i>k_x,b_y<b_x$
  • 这样就易得一个结论,按上述方法将直线排序,一条直线能染得部分是向右最后一个$b$比它小的和向左最后一个$b$比它大的
  • 问题转化为了有$n$个区间,询问覆盖总长的方案数,注意到这些区间不存在完全包含关系,$DP$即可
  • $f(n)$为染色到$n$的方案数,把这些区间按右端点排序再枚举右端点转移即可。这个可以前缀和优化

code:

#include<algorithm>
#include<cstring>
#include<cstdio>
#include<iostream>
using namespace std;
typedef long long ll; const int N=5e5+;
const ll mo=1e9+;
int n;
struct node
{
int k,b;
int id;
}p[N];
bool cmpk(node a,node b) {return a.k==b.k?a.b<b.b:a.k<b.k;}
bool cmpb(node a,node b) {return a.b<b.b;}
struct seg
{
int l,r;
}c[N];
bool operator < (seg a,seg b) {return a.r==b.r?a.l<b.l:a.r<b.r;}
inline int read()
{
char ch=getchar();int s=,f=;
while (ch<''||ch>'') {if (ch=='-') f=-;ch=getchar();}
while (ch>=''&&ch<='') {s=(s<<)+(s<<)+ch-'';ch=getchar();}
return s*f;
}
ll f[N],s[N];
int main()
{
freopen("river.in","r",stdin);
freopen("river.out","w",stdout);
n=read();
for (int i=;i<=n;i++) p[i].b=read(),p[i].k=read();
sort(p+,p++n,cmpk);
for (int i=;i<=n;i++) p[i].id=i;
sort(p+,p++n,cmpb);
int mi=n;
for (int i=n;i>=;i--) mi=min(mi,p[i].id),c[p[i].id].l=mi;
int mx=;
for (int i=;i<=n;i++) mx=max(mx,p[i].id),c[p[i].id].r=mx;
sort(c+,c++n);
int pos=;
for (int i=;i<=n;i++)
{
while (pos<c[i].r-)
{
++pos;
s[pos]=(s[pos-]+f[pos])%mo;
}
(f[c[i].r]*=)%=mo;//这个区间可以选,也可以不选
(f[c[i].r]+=s[c[i].r-]-(c[i].l>=?s[c[i].l-]:)+mo)%=mo;
if (c[i].l==) (f[c[i].r]+=)%=mo;
}
printf("%lld\n",f[n]%mo);
return ;
}

[jzoj 6073] 河 解题报告 (DP)的更多相关文章

  1. [jzoj 5661] 药香沁鼻 解题报告 (DP+dfs序)

    interlinkage: https://jzoj.net/senior/#contest/show/2703/0 description: solution: 注意到这本质就是一个背包,只是选了一 ...

  2. ACM: HDU 1028 Working out 解题报告-DP

    Working out time limit per test  2 seconds memory limit per test  256 megabytes input  standard inpu ...

  3. [BZOJ1151][CTSC2007]动物园zoo 解题报告|DP|位运算

    Description 最近一直在为了学习算法而做题,这道题是初一小神犇让我看的.感觉挺不错于是写了写. 这道题如果是一条线的话我们可以构造一个DP f[i,j]表示以i为起点,i,i+1...i+4 ...

  4. [jzoj 5662] 尺树寸泓 解题报告 (线段树+中序遍历)

    interlinkage: https://jzoj.net/senior/#contest/show/2703/1 description: solution: 发现$dfs$序不好维护 注意到这是 ...

  5. [NOIP2017] 逛公园 解题报告(DP)

    我很不想说 在我的AC代码上我打了表,但实在没有办法了.莫名的8,9个点RE.然而即便是打表...也花了我很久. 这大概是NOIP2017最难的题了,为了让不懂的人更容易理解,这篇题解会比较详细 我的 ...

  6. [USACO09JAN] 气象测量/气象牛The Baric Bovine 解题报告(DP)

    题目链接:https://www.luogu.org/problemnew/show/P2933 Description 为了研究农场的气候,Betsy帮助农夫John做了N(1 <= N &l ...

  7. [JXOI 2018] 守卫 解题报告 (DP)

    interlinkage: https://www.luogu.org/problemnew/show/P4563 description: solution: 注意到对于范围$[l,r]$,$r$这 ...

  8. [JZOJ 4307] [NOIP2015模拟11.3晚] 喝喝喝 解题报告

    题目链接: http://172.16.0.132/senior/#main/show/4307 题目: 解题报告: 题目询问我们没出现坏对的连续区间个数 我们考虑从左到有枚举右端点$r$,判断$a[ ...

  9. 2020.6.16 night 解题报告

    2020.6.16 night 解题报告 link 标签(空格分隔): 题解 概率与期望 T1 : Crossing Rivers UVA - 12230 SB题. 很唬人的一个连续期望. 很明显,在 ...

随机推荐

  1. SLAM: VSLAM扫盲之旅

    在<机器人手册> 第2卷,这本书里面,第23章讲述了:三维视觉和基于视觉的实时定位于地图重建.在第37章里面,讲述了 同时定位与建图.指出了SLAM的三种基本方法. 一种是EKF的方法,但 ...

  2. 12 Python+selenium对日期控件进行处理(采用执行JS脚本)

    [环境信息] Python34+IE+windows2008 [说明] 1.对于日期控件,没有办法通过定位元素再直接传值的方式处理.可以采用执行JavaScript处理. PS:还要去学学js怎么写, ...

  3. 实现Modbus ASCII多主站应用

    1.更新设计关于原来的协议栈在Modbus ASCII主站应用时所存在的局限性与Modbus RTU也是一样的,所以我们不分析它的不足,只讨论更新设计.我们将主站及其所访问的从站定义为通用的对象,而当 ...

  4. Python 集合 day3

    集合(set)是一个无序的不重复元素序列. 可以使用大括号 { } 或者 set() 函数创建集合,集合用{},里面是一个一个元素,不同于key-value形式的字典: 注意:创建一个空集合必须用 s ...

  5. hadoop中的job.setOutputKeyClass与job.setMapOutputKeyClass

    初学mr时,觉得没什么,但是学了一段时间,重新复习时发现程序中mr程序中一般都会有 hadoop中的job.setOutputKeyClass(theClass)与job.setOutputValue ...

  6. lucene_01_入门程序

    索引和搜索流程图: 1.绿色表示索引过程,对要搜索的原始内容进行索引构建一个索引库,索引过程包括:确定原始内容即要搜索的内容->采集文档->创建文档->分析文档->素引文档2. ...

  7. Java基础学习总结(67)——Java接口API中使用数组的缺陷

    如果你发现在一个接口使用有如下定义方法: public String[] getParameters(); 那么你应该认真反思.数组不仅仅老式,而且我们有合理的理由避免暴露它们.在这篇文章中,我将试图 ...

  8. 0320SQL中的where条件,在数据库中提取与应用浅析

    转自 何登成的技术博客 追求技术的道路上,10年如一日     首页 关于我 RSS 订阅 © 2012-2017 何登成的技术博客   SQL中的where条件,在数据库中提取与应用浅析 3月 3r ...

  9. mysql 易错误理解

    MySQL作为数据库的一大主力军,到处存在于我们各种系统中,相信大家都不陌生!但是,你知道你能用不代表你知道细节,那我们就来盘点盘点其中一些我们平时不太注意的地方,一来为了有趣,二来为了不让自己踩坑. ...

  10. [jQuery]$.get跨域提交不发送原因

    使用 $.ajax({ url: "http://pastebin.com/embed_js.php?i=sy9gt3FR", dataType: "jsonp" ...