URAL 1203 Scientific Conference(贪心 || DP)
之前一直在刷计算几何,邀请赛连计算几何的毛都买见着,暑假这一段时间就做多校。补多校的题目。刷一下一直薄弱的DP。多校假设有计算几何一定要干掉-。-
题意:给你N个报告会的開始时间跟结束时间。问你做多能够听几场报告会。要求报告会之间至少间隔为1。
思路:事实上是个活动安排问题。能够用贪心也能够用DP,贪心写起来会比較简单一些。由于练习DP,所以又用DP写了一遍。
贪心的话就是一个非常easy的活动选择问题,从结束时间入手,找每次的最优选择。
贪心:
struct node{
int b, e;
} N[100005]; int cmp(node x, node y){
if(x.e == y.e)
return x.b < y.b;
return x.e < y.e;
} int n;
int main()
{
scanf("%d", &n);
for(int i = 0; i < n; ++i){
scanf("%d%d", &N[i].b, &N[i].e);
}
sort(N, N+n, cmp);
int ans = 0;
int t = 0;
for(int i = 0; i < n; ++i)
{
if(N[i].b >= t)
{
ans++;
t = N[i].e+1;
}
}
printf("%d\n", ans); return 0;
}
DP:
struct node{
int b, e;
} N[100005]; int cmp(node x, node y){
if(x.e == y.e)
return x.b < y.b;
return x.e < y.e;
} int n;
int dp[30005];
int k[30005];
int main()
{
scanf("%d", &n);
int last = -1;
for(int i = 0; i < n; ++i){
scanf("%d%d", &N[i].b, &N[i].e);
last = max(last, N[i].e);
}
sort(N, N+n, cmp);
for(int i = 0; i < n; ++i)
{
dp[N[i].e] = 1; ///记录结束时间是在
k[N[i].e] = N[i].b;///记录结束时间的活动相应的開始时间
///之前有排序所以选择会覆盖 会是最优的
}
for(int i = 1; i <= last; ++i)
{///DP时间
if(k[i]) ///假设当前时间点有结束的活动
dp[i] = max(dp[i-1], dp[k[i]-1]+1);
dp[i] = max(dp[i], dp[i-1]);///假设当前时间点没有结束的活动
}
printf("%d\n", dp[last]); return 0;
}
URAL 1203 Scientific Conference(贪心 || DP)的更多相关文章
- URAL 1203 Scientific Conference 简单dp 难度:0
http://acm.timus.ru/problem.aspx?space=1&num=1203 按照结束时间为主,开始时间为辅排序,那么对于任意结束时间t,在此之前结束的任务都已经被处理, ...
- ural 1203. Scientific Conference(动态规划)
1203. Scientific Conference Time limit: 1.0 second Memory limit: 64 MB Functioning of a scientific c ...
- URAL 1203 Scientific Conference dp?贪心
题目:click here 分明就是贪心怎么会在dp的专题 #include <bits/stdc++.h> using namespace std; typedef unsigned l ...
- URAL 1203. Scientific Conference(瞎搞)
题目链接 本来觉得这不是经典的贪心吗..果断水一次,wa了,看了看discuss,发现貌似不好水,土土的DP了一下,复杂度很高了,又T了...然后想想单调队列,二分什么的...不好往上加,直接搞了标记 ...
- ural 1203. Scientific Conference
http://acm.timus.ru/problem.aspx?space=1&num=1203 #include <cstdio> #include <cstring&g ...
- 【BZOJ-3174】拯救小矮人 贪心 + DP
3174: [Tjoi2013]拯救小矮人 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 686 Solved: 357[Submit][Status ...
- BZOJ_3174_[Tjoi2013]拯救小矮人_贪心+DP
BZOJ_3174_[Tjoi2013]拯救小矮人_贪心+DP Description 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀 ...
- 洛谷P4823 拯救小矮人 [TJOI2013] 贪心+dp
正解:贪心+dp 解题报告: 传送门! 我以前好像碰到过这题的说,,,有可能是做过类似的题qwq? 首先考虑这种显然是dp?就f[i][j]:决策到了地i个人,跑了j个的最大高度,不断更新j的上限就得 ...
- 【bzoj5073】[Lydsy1710月赛]小A的咒语 后缀数组+倍增RMQ+贪心+dp
题目描述 给出 $A$ 串和 $B$ 串,从 $A$ 串中选出至多 $x$ 个互不重合的段,使得它们按照原顺序拼接后能够得到 $B$ 串.求是否可行.多组数据. $T\le 10$ ,$|A|,|B| ...
随机推荐
- flink watermark介绍
转发请注明原创地址 http://www.cnblogs.com/dongxiao-yang/p/7610412.html 一 概念 watermark是flink为了处理eventTime窗口计算提 ...
- python 类的使用实例方法
class A: dict_1 = 456 def __init__(self): self.dict_1 = 'abcdsafdsf' #当增加@staticmethod 时为类方法 @static ...
- linux命令之数据盘格式化挂载
1,查看数据盘 在没有分区和格式化数据盘之前,使用”df -h “命令是无法看到数据盘的,可以通过 fdisk -l 查看机器情况(找出所有硬盘个数及设备名称) 提示:若没有发现/dev/xvdb ...
- jquery和css3打造超梦幻的三维动画背景
今天为大家带来的是一款由jquery和css3实现的超级梦幻的背景效果.绿色的小原点由远到近,由近到远一种飞跃效果.效果非常好看,我们一起看下效果图: 在线预览 源码下载 我们一起看下实现的代码. ...
- 【技术】正則表達式—匹配电话号码,网址链接,Email地址
#pragma mark - 正则匹配电话号码.网址链接.Email地址 + (NSMutableArray *)addHttpArr:(NSString *)text { //匹配网址链接 NSSt ...
- at org.apache.hadoop.util.RunJar.main(RunJar.java:153)
关于手动编译hadoop入门例子WordCount并执行 之前做的例子都是用hadoop中已经编译好jar包来运行示例的但是这次想要手动编译个实例,练下手没想到还是遇到点了小困难 [root@cent ...
- oracle 字符集 AL32UTF8、UTF8
简介:ORACLE数据库字符集,即Oracle全球化支持(Globalization Support),或即国家语言支持(NLS)其作用是用本国语言和格式来存储.处理和检索数据.利用全球化支持,ORA ...
- [Django学习]模板
模板介绍 作为Web框架,Django提供了模板,可以很便利的动态生成HTML 模版系统致力于表达外观,而不是程序逻辑 模板的设计实现了业务逻辑(view)与显示内容(template)的分离,一个视 ...
- FTP原理
1.1.1 ftp的主动模式和被动模式 扩展重要. FTP是仅基于TCP的服务,不支持UDP. 与众不同的是FTP使用2个端口,一个数据端口和一个命令端口(也可叫做控制端口).通常来说这两个端口是21 ...
- Workerman
What is it Workerman is a library for event-driven programming in PHP. It has a huge number of featu ...