UVA 11134 FabledRooks 传说中的车 (问题分解)
摘要:贪心,问题分解。
因为行列无关,所以这个二维问题可以分解成两个一维问题。
优先队列实现:类似区间点覆盖的问题,先按照左端点排序,相同然后在按右端点排序(灵活性小的优先选)。最优的选法,当然是要使选的这个点经过的区间越少越好,那么就选最左边的点,因为选右边可能多经过区间,一定不比选最左边的更优。选完之后,就要把选过的点last忽略,并且把包含这个点的区间做修改,这个修改是动态的,可用优先队列
71ms
#include<bits/stdc++.h>
using namespace std; const int maxn = ;
struct seg
{
int l,r,id;
seg(int L,int R) { l = L; r = R; }
seg(){}
bool operator < (const seg& rhs) const {
return l > rhs.l || ( l == rhs.l && r > rhs.r);
}
}; seg dim[][maxn];
int rooks[maxn][]; priority_queue<seg> q; bool solve(int n,int d)
{
for(int i = ; i < n; i++){
q.push(dim[d][i]);
}
int last = ;
int id = ;
while(q.size()){
seg cur = q.top(); q.pop();
if(cur.l>cur.r) return false;
if(cur.l<=last) {
cur.l = last + ; q.push(cur);
}else {
last = cur.l;
rooks[cur.id][d] = cur.l;
}
}
return true;
} int main()
{
//freopen("in.txt","r",stdin);
int n;
seg *R = dim[], *C = dim[];
for(int i = ; i < maxn; i++) dim[][i].id = dim[][i].id = i;
while(~scanf("%d",&n)&&n){
for(int i = ; i < n; i++){
scanf("%d%d%d%d",&R[i].l,&C[i].l,&R[i].r,&C[i].r);
}
if(solve(n,)&&solve(n,)){
for(int i = ; i < n; i++){
printf("%d %d\n",rooks[i][],rooks[i][]);
}
}else puts("IMPOSSIBLE"); }
return ;
}
优先队列
另外一种贪心,直接按照右端点排序,优先处理右端点最小的区间,因为它的灵活性最小。从左往右边选点,使当前点尽量避免经过没有选点的区间。
这样做的效率要更高
11ms
#include<bits/stdc++.h>
using namespace std; const int maxn = ;
struct seg
{
int l,r,id;
bool operator < (const seg& rhs) const {
return r < rhs.r ;
}
}; seg dim[][maxn];
int rooks[maxn][]; bool solve(int n,int d)
{
int last = -;
seg *Dim = dim[d];
bool vis[n+];
memset(vis,,sizeof(vis));
sort(Dim,Dim+n);
for(int i = ; i < n; i++){
int j;
for(j = Dim[i].l; j <= Dim[i].r; j++) if(!vis[j]) {
rooks[Dim[i].id][d] = j; vis[j] = true; break;
}
if(j>Dim[i].r) return false;
}
return true;
} int main()
{
int n;
seg *R = dim[], *C = dim[];
while(~scanf("%d",&n)&&n){
for(int i = ; i < n; i++){
scanf("%d%d%d%d",&R[i].l,&C[i].l,&R[i].r,&C[i].r);
R[i].id = C[i].id = i;
}
if(solve(n,)&&solve(n,)){
for(int i = ; i < n; i++){
printf("%d %d\n",rooks[i][],rooks[i][]);
}
}else puts("IMPOSSIBLE"); }
return ;
}
右端排序
UVA 11134 FabledRooks 传说中的车 (问题分解)的更多相关文章
- UVa 11134 Fabled Rooks (贪心+问题分解)
题意:在一个n*n的棋盘上放n个车,让它们不互相攻击,并且第i辆车在给定的小矩形内. 析:说实话,一看这个题真是没思路,后来看了分析,原来这个列和行是没有任何关系的,我们可以分开看, 把它变成两个一维 ...
- 01_传说中的车(Fabled Rooks UVa 11134 贪心问题)
问题来源:刘汝佳<算法竞赛入门经典--训练指南> P81: 问题描述:你的任务是在n*n(1<=n<=5000)的棋盘上放n辆车,使得任意两辆车不相互攻击,且第i辆车在一个给定 ...
- UVA - 11134 Fabled Rooks[贪心 问题分解]
UVA - 11134 Fabled Rooks We would like to place n rooks, 1 ≤ n ≤ 5000, on a n × n board subject to t ...
- uva 11134 - Fabled Rooks(问题转换+优先队列)
题目链接:uva 11134 - Fabled Rooks 题目大意:给出n,表示要在n*n的矩阵上放置n个车,并且保证第i辆车在第i个区间上,每个区间给出左上角和右小角的坐标.另要求任意两个车之间不 ...
- UVA 11134 Fabled Rooks 贪心
题目链接:UVA - 11134 题意描述:在一个n*n(1<=n<=5000)的棋盘上放置n个车,每个车都只能在给定的一个矩形里放置,使其n个车两两不在同一行和同一列,判断并给出解决方案 ...
- UVA - 11134 Fabled Rooks(传说中的车)(贪心)
题意:在n*n的棋盘上放n个车,使得任意两个车不相互攻击,且第i个车在一个给定的矩形Ri之内,不相互攻击是指不同行不同列,无解输出IMPOSSIBLE,否则分别输出第1,2,……,n个车的坐标. 分析 ...
- UVa 11134 传说中的车
https://vjudge.net/problem/UVA-11134 题意:在n*n的棋盘上放n个车,使得任意两个车不相互攻击,且第i个车在一个给定的矩形Ri之内.用4个整数xli,yli,xri ...
- 【uva 11134】Fabled Rooks(算法效率--问题分解+贪心)
题意:要求在一个N*N的棋盘上放N个车,使得它们所在的行和列均不同,而且分别处于第 i 个矩形中. 解法:问题分解+贪心. 由于行.列不相关,所以可以先把行和列均不同的问题分解为2个"在区间 ...
- UVA - 11134 Fabled Rooks问题分解,贪心
题目:点击打开题目链接 思路:为了满足所有的车不能相互攻击,就要保证所有的车不同行不同列,于是可以发现,行与列是无关的,因此题目可以拆解为两个一维问题,即在区间[1-n]之间选择n个不同的整数,使得第 ...
随机推荐
- Linux 之问题集锦(一)
1. 打开目录时,怎么只显示一个窗口 计算机 -- 编辑 -- 首选项 -- 行为 -- 总是总浏览器窗口中打开 2. linux中添加PATH时出现 Found a swap file by the ...
- Centos7.1下Docker的安装-yum方法
在CentOS7上安装1. 查看系统版本: $ cat /etc/redhat-release CentOS Linux release 7.0.1406 (Core) 2. 安装docker $ y ...
- css圆角不圆和1px方案
1.圆角不圆 比如需要我们画一个 r 为 5px 的圆,如果我们使用 rem 作为单位,我们很快会发现在一些机型上的图案不圆,会呈现椭圆形.这是由于 rem 转 px 会存在精度丢失问题. 所以这个时 ...
- Java怎么把一个.log文件,以text文件方式打开,显示在桌面
总要有一个开始吧 群里面有一个哥们,问这个问题,索性记录下来, quextion: Java怎么把一个.log文件,以text文件方式打开,显示在桌面 anwser: 这里注意一个问题:拼接路径的时候 ...
- 1.检索数据 ---SQL
相关提示: 结束SQL语句 多条SQL语句必须以分号(:)分隔.多数DBMS不需要在单条SQL语句后加分号,但也有DBMS可能必须在单条SQL语句后加上分号.当然,如果愿意可以总是加上分号.事实上,即 ...
- P2184 贪婪大陆 树状数组
树状数组帅炸了....又被一道水题轻虐,又被学长指出了一个错误....我太菜了QAQ 开两个树状数组,一个记录左端点,一个记录右端点: 共有cnt(总数) - (<l的右端点数目) - (> ...
- NET Core Hosting
ASP.NET Core 运行原理解剖[1]:Hosting ASP.NET Core 是新一代的 ASP.NET,第一次出现时代号为 ASP.NET vNext,后来命名为ASP.NET 5,随 ...
- 《深入理解java虚拟机》笔记(7)JVM调优(分代垃圾收集器)
以下配置主要针对分代垃圾回收算法而言. 一.堆大小设置 年轻代的设置很关键 JVM中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制:系统的可用虚拟内存限制:系统的可用 ...
- TDH-search汇报理解
题目:海量数据查询开头:1.自我介绍:2.题目切入: 什么是海量数据查询?(海量数据,快速,符合要求) 几个常用场景(搜索引擎,百度:话单查询:影像平台,高铁)3.展示目录:架构,案例,平台规划 4. ...
- Jquery会死吗?我为什么不用vue写富文本!
一.事件背景: 我最近开源了一个个人耗时半年打造的富文本及一套适用于web后台的ui框架,在gitee上受到网友们的关注,部分网友对我采用jquery的技术栈提出了质疑.总结起来:无非是jquery已 ...