博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ZOJ 2319 Beautiful People
阅读量:6841 次
发布时间:2019-06-26

本文共 998 字,大约阅读时间需要 3 分钟。

            LIS。先按S降序升序再按B降序排序(如果B不按降序排序的话就会覆盖掉正解),然后再对B用O(nlog(n))的LIS求解就可以了。用d数组标记每个元素在上升序列中的位置,然后根据d倒着找id就可以了。

 

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define FF(i, a, b) for(int i=a; i
=b; i--)#define REP(i, n) for(int i=0; i
rhs.b); }}p[N];int g[N];int d[N];int main(){ int s, b, t, n, ans; scanf("%d", &t); while(t --) { scanf("%d", &n); for(int i = 0; i < n; i ++) { scanf("%d%d", &s, &b); p[i].s = s, p[i].b = b, p[i].id = i + 1; } sort(p, p + n);ans = 0; for(int i = 1; i <= n; i ++) g[i] = INF; for(int i = 0; i < n; i ++) { int k = lower_bound(g+1, g+n+1, p[i].b) - g; g[k] = p[i].b; d[i] = k; ans = max(ans, k); } printf("%d\n", ans); int pt = -1; for(int i = n - 1; i >= 0; i --) { if(p[i].s != pt && d[i] == ans) { printf("%d", p[i].id); if(ans) putchar(' '); ans --;pt = p[i].s; } if(!ans) break; }puts(""); if(t) puts(""); }}

 

 

转载地址:http://ikdul.baihongyu.com/

你可能感兴趣的文章
node.js构建静态服务器
查看>>
WWDC 2018:IAP最佳实践并增强活动营销功能
查看>>
ng-notadd 0.10.1,基于 Angular7 和 material2 的中后台解决方案
查看>>
米筐三季度策略精选
查看>>
从零搭建React项目
查看>>
LAMP和LNMP加速与缓存优化
查看>>
解决scrollView上subView下移20point问题的一种方式
查看>>
定时任务与发送邮件
查看>>
前端面试之关于HTTP协议
查看>>
利用 Matplotlib 绘制数据图形(二)
查看>>
iOS概念攻坚之路(二):Runtime
查看>>
关于前端请求发送时间时而长时而短问题(stalled a lot)
查看>>
Python 工匠:编写条件分支代码的技巧
查看>>
记一次前端面试经历
查看>>
带你探索JUnit 5.4
查看>>
<暗时间> 时间, 不在于你拥有多少, 而在于你怎样使用
查看>>
Git的使用--如何将本地项目上传到Github
查看>>
单例 - iOS
查看>>
戛纳电影节百花齐放,中国明星衣着品味紧跟时尚前沿
查看>>
TensorFlowPlayground好玩的tensorflow入门神器
查看>>