博客
关于我
【DG特长生2018 T4】【SSL 2888】【luogu P2003】平板游戏问题 / PLATFORME 平板
阅读量:338 次
发布时间:2019-03-04

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

平板游戏问题 / PLATFORME 平板

题目链接: /

题目大意

有一些横着的木板,然后它两段要有支柱,支柱可以搭在它下面木板,如果下面没有就搭在地板上。

然后问你总共要的支柱的长度是多少。

思路

我们可以很容易的想到,可以直接模拟。

就直接记录每个 x 坐标上有哪些木板。

然后我们把这个 x 坐标的每个木板按高度从大到小排序。
然后这个木板在这个位置要有支柱,那它支柱的长度就是它的高度减下一个的高度。

然后就可以了。

代码

#include
#include
using namespace std;struct block { int y, x1, x2;}a[101];struct bord{ int y, num, important;};int n, number[10001], ans, important_num[10001];bord x[10001][104];bool cmp(bord x, bord y) { if (x.y == y.y) return x.important > y.important; return x.y > y.y;}int main() { // freopen("platforme.in", "r", stdin);// freopen("platforme.out", "w", stdout); scanf("%d", &n); for (int i = 1; i <= n; i++) { scanf("%d %d %d", &a[i].y, &a[i].x1, &a[i].x2); a[i].x2--; for (int j = a[i].x1; j <= a[i].x2; j++) { x[j][++number[j]] = (bord){ a[i].y, i, 0}; if (j == a[i].x1 || j == a[i].x2) x[j][number[j]].important = 1, important_num[j]++;; } } for (int i = 1; i <= 10000; i++) { // if (!important_num[i]) continue; sort(x[i] + 1, x[i] + number[i] + 1, cmp); for (int j = 1; j <= number[i]; j++) if (x[i][j].important) ans += x[i][j].y - x[i][j + 1].y; } printf("%d", ans); fclose(stdin); fclose(stdout); return 0;}

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

你可能感兴趣的文章
nginx一些重要配置说明
查看>>
Nginx一网打尽:动静分离、压缩、缓存、黑白名单、跨域、高可用、性能优化......
查看>>
Nginx下配置codeigniter框架方法
查看>>
Nginx与Tengine安装和使用以及配置健康节点检测
查看>>
Nginx中使用expires指令实现配置浏览器缓存
查看>>
Nginx中使用keepalive实现保持上游长连接实现提高吞吐量示例与测试
查看>>
Nginx中如何配置WebSocket代理?
查看>>
Nginx中实现流量控制(限制给定时间内HTTP请求的数量)示例
查看>>
nginx中配置root和alias的区别
查看>>
nginx主要流程(未完成)
查看>>
Nginx之二:nginx.conf简单配置(参数详解)
查看>>
vue中各模块加载和渲染的过程
查看>>
Nginx从入门到精通
查看>>
Nginx从入门到精通(全)
查看>>
Nginx从安装到高可用,一篇搞定!
查看>>
Nginx代理websocket配置(解决websocket异常断开连接tcp连接不断问题)
查看>>
Nginx代理初探
查看>>
nginx代理地图服务--离线部署地图服务(地图数据篇.4)
查看>>
Nginx代理外网映射
查看>>
Nginx代理模式下 log-format 获取客户端真实IP
查看>>