URAL - 1078 Segments
题目大意:有n条线段,一个线段a 完全覆盖另一个线段b 当且仅当,a.l < b.l && a.r>b.r。问你
一个线段覆盖一个线段再覆盖一个线段再.......,问你最多几个线段属于这种关系,并打印出路径。
这题的的 n 太小了,n^3的方法都能过。
思路:1. 我们设dp[ i ] 为 以 i 位最外层的答案为多少,n^3的方法是,我们先将所有dp的值设为1,
枚举最外层的点,再枚举其内层的点更新,一次更新肯定是不够的,我们更新到它没有更新了再
退出,感觉和最短路的贝尔曼算法相似,这种方法显然复杂度很高。
2.第一种方法中我们显然是无脑地枚举边,怎么才能减少不必要的操作呢。我们将边按左端点的
大小排序,然后从后往前枚举最外层的点,因为是按左端点排序的而且是从后往前枚举,所以能
被当前点包含的肯定在该点的后面,这样我们每次更新当前点之后,当前点的dp值肯定是最优值,
这样我们就将复杂度降到了n^2。(虽然我排了序,但我是傻逼从前往后枚举,虽然优化了一点,还是n^3)
3.这是一个学姐的方法,也是复杂度应该也是n^2,我们将每条线段都看成一个点,然后如果一条
线段能包含另一条线段,我们就在他们之间连一条有向边。那么我们就从各个点出发,看每个点
到最深处的路径长度是多少,显然也能用记忆化搜索。(这个方法我感觉好牛逼啊)
这里贴一下第二种方法的代码吧QAQ
#include<bits/stdc++.h>
using namespace std;
const int N=;
int n,pre[],dp[];
struct node
{
int fi,se,id;
bool operator < (const node &t)const
{
return fi<t.fi;
}
}seg[];
int main()
{
cin>>n;
for(int i=;i<=n;i++) scanf("%d%d",&seg[i].fi,&seg[i].se),seg[i].id=pre[i]=i;
sort(seg+,seg+n+);
for(int i=;i<=n;i++) dp[i]=;
for(int i=n;i>=;i--)
{
for(int j=i+;j<=n;j++)
{
if(seg[j].fi>seg[i].fi && seg[j].se<seg[i].se && dp[i]<dp[j]+)
{
dp[i]=dp[j]+;
pre[i]=j;
}
}
}
int mx=,item;
for(int i=;i<=n;i++)
{
if(dp[i]>mx)
{
mx=dp[i];
item=i;
}
}
cout<<mx<<endl;
vector<int> ans;
ans.push_back(seg[item].id);
while(item!=pre[item])
{
item=pre[item];
ans.push_back(seg[item].id);
}
int len=ans.size();
for(int i=len-;i>=;i--) printf("%d%c",ans[i],i== ? '\n':' ');
return ;
}
URAL - 1078 Segments的更多相关文章
- URAL(DP集)
这几天扫了一下URAL上面简单的DP 第一题 简单递推 1225. Flags #include <iostream> #include<cstdio> #include< ...
- ural 1273. Tie
1273. Tie Time limit: 1.0 secondMemory limit: 64 MB The subway constructors are not angels. The work ...
- URAL 1776 C - Anniversary Firework DP
C - Anniversary FireworkTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/c ...
- ural 1303 Minimal Coverage【贪心】
链接: http://acm.timus.ru/problem.aspx?space=1&num=1303 http://acm.hust.edu.cn/vjudge/contest/view ...
- [LeetCode] Number of Segments in a String 字符串中的分段数量
Count the number of segments in a string, where a segment is defined to be a contiguous sequence of ...
- Greenplum记录(一):主体结构、master、segments节点、interconnect、performance monitor
结构:Client--master host--interconnect--segment host 每个节点都是单独的PG数据库,要获得最佳的性能需要对每个节点进行独立优化. master上不包含任 ...
- Application package 'AndroidManifest.xml' must have a minimum of 2 segments.
看了源码就是packagename里面必须包含一个. 源码在: ./sdk/eclipse/plugins/com.android.ide.eclipse.adt/src/com/android/id ...
- segments&cache
Segments 执行效果 命令 在 sense 里边执行 GET /abcd/_segments 前边的是索引名称,后边是请求 段信息 说明 索引是面向分片的,是由于索引是由一个或多个分片( ...
- BZOJ 1078: [SCOI2008]斜堆
1078: [SCOI2008]斜堆 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 770 Solved: 422[Submit][Status][ ...
随机推荐
- 小程序Promise不支持finally解决方案
小程序Promise不支持finally解决方案 代码片段 点击链接即可在微信开发者工具中查看代码wechatide://minicode/t2eidemj7P3X git地址 基本思路 小程序的Pr ...
- Vue.js入门系列教程(二)
过滤器:filter 全局过滤器 <!DOCTYPE html> <html lang="en"> <head> <meta charse ...
- BZOJ3527 [Zjoi2014]力 【fft】
题目 给出n个数qi,给出Fj的定义如下: 令Ei=Fi/qi,求Ei. 输入格式 第一行一个整数n. 接下来n行每行输入一个数,第i行表示qi. 输出格式 n行,第i行输出Ei.与标准答案误差不超过 ...
- Linux - 操作系统信号
linux操作系统提供的信号 kill -l # 查看linux提供的信号 trap # shell使用 trap 捕捉退出信号 # 发送信号一般有两种原因: # (被动式) 内核检测到一个系统事件. ...
- UE4中Bebavior Tree中Delay及其后面代码失效的原因
具体原因是因为节点的执行过程中,该节点及其父节点的Decorator条件不满足,而节点又受到flow control的影响,导致中途强制结束了Task节点的执行,具体如下. UE4中的Behavior ...
- linux bash的重定向
cnblogs原创 下面几种bash重定向各表示什么意思? find / -name passwd > /dev/null >& > /dev/null find / -na ...
- 【转】ReactNative&weex&DeviceOne对比
React Native出来有一段时间了,国内的weex和deviceone是近期发布的,我可以说从2011年就开始关注快速开发的跨平台平台技术了,接触过phoneGap.数字天堂.appcan等早期 ...
- ubuntu14.04 安装 openssh-server
ubuntu自带的有openssh-client,所以可以通过 ssh username@host 来远程连接linux 可是要想通过ssh被连接,ubuntu系统需要有openssh-server, ...
- SpringBoot集成Spring Security(授权与认证)
⒈添加starter依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifact ...
- UML和模式应用4:初始阶段(4)--需求制品之用例模型模板示例
1. 前言 UP开发包括四个阶段:初始阶段.细化阶段.构建阶段.移交阶段: UP每个阶段包括 业务建模.需求.设计等科目: 其中需求科目对应的需求制品包括:设想.业务规则.用例模型.补充性规格说明.词 ...