思路:把每个点拆成(d+1)*n列,行数为可拆分区间数。对所有的有i号点拆分出来的行都要建一条该行到i列的边,那么就能确保有i号点拆出来的行只能选择一行。

#include<set>
#include<cmath>
#include<queue>
#include<cstdio>
#include<vector>
#include<string>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define pb push_back
#define mp make_pair
#define Maxn 1010
#define Maxm 80002
#define LL __int64
#define Abs(x) ((x)>0?(x):(-x))
#define lson(x) (x<<1)
#define rson(x) (x<<1|1)
#define inf 100000
#define lowbit(x) (x&(-x))
#define clr(x,y) memset(x,y,sizeof(x))
#define Mod 1000000007
using namespace std;
int U[Maxn*],D[Maxn*],L[Maxn*],R[Maxn*],S[Maxn*],H[Maxn],C[Maxn*],road[Maxn],id,d,n,m;
int g[][],row[Maxn*];
int vi[Maxn];
struct interv{
int s,e,i;
int operator <(const interv &temp) const{
if(s==temp.s)
return e>temp.e;
return s<temp.s;
}
}p[Maxn],ans[Maxn];
void init(int n)
{
int i;
for(i=;i<=n;i++){
D[i]=U[i]=i;
L[i+]=i;
R[i]=i+;
S[i]=;
}
R[n]=;
id=n+;
memset(H,-,sizeof(H));
}
void ins(int r,int c)
{
int i,j;
D[id]=D[c];
U[id]=c;
U[D[c]]=id;
D[c]=id;
if(H[r]<)
H[r]=L[id]=R[id]=id;
else{
L[id]=H[r];
R[id]=R[H[r]];
L[R[H[r]]]=id;
R[H[r]]=id;
}
S[c]++;
row[id]=r;
C[id++]=c;
}
void Remove(int c)
{
int i,j;
L[R[c]]=L[c];
R[L[c]]=R[c];
for(i=D[c];i!=c;i=D[i]){
for(j=R[i];j!=i;j=R[j]){
D[U[j]]=D[j];
U[D[j]]=U[j];
S[C[j]]--;
}
}
}
void Resume(int c)
{
int i,j;
L[R[c]]=c;
R[L[c]]=c;
for(i=D[c];i!=c;i=D[i]){
for(j=R[i];j!=i;j=R[j]){
D[U[j]]=j;
U[D[j]]=j;
S[C[j]]++;
}
}
}
bool dfs(int step)
{
int i,j,k,c,temp;
if(R[]==){
for(i=;i<step;i++)
vi[ans[road[i]].i]=road[i];
for(i=;i<=n;i++){
if(!vi[i]) printf("0 0\n");
else printf("%d %d\n",ans[vi[i]].s,ans[vi[i]].e);
}
return true;
}
temp=inf;
for(i=R[];i;i=R[i]) if(S[i]<temp){
temp=S[i];
c=i;
}
Remove(c);
for(i=D[c];i!=c;i=D[i]){
road[step]=row[i];
for(j=R[i];j!=i;j=R[j]){
Remove(C[j]);
}
if(dfs(step+))
return true;
for(j=L[i];j!=i;j=L[j])
Resume(C[j]);
}
Resume(c);
return false;
}
void build()
{
int i,j,sz,k,r;
init(n*(d+));
int cnt=;
for(i=;i<=n;i++){
for(j=p[i].s;j<=p[i].e;j++){
for(k=p[i].s;k<=j;k++){
ins(cnt,i);
ans[cnt].s=k,ans[cnt].e=j,ans[cnt].i=i;
for(r=;r<=n;r++){
if(!g[i][r]) continue;
for(int d=k;d<=j;d++){
ins(cnt,n+(d-)*n+r);
}
}
cnt++;
}
}
ins(cnt,i);
ans[cnt].s=,ans[cnt].e=,ans[cnt].i=i;
cnt++;
}
}
int main()
{
int i,j,u,v;
while(scanf("%d%d%d",&n,&m,&d)!=EOF){
memset(g,,sizeof(g));
for(i=;i<=m;i++){
scanf("%d%d",&u,&v);
g[u][v]=g[v][u]=;
}
for(i=;i<=n;i++){
g[i][i]=;
scanf("%d%d",&p[i].s,&p[i].e);
p[i].i=i;
}
build();
if(!dfs())
printf("No solution\n");
printf("\n");
}
return ;
}

hdu 3663 DLX的更多相关文章

  1. 搜索(DLX):HDU 3663 Power Stations

    Power Stations Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  2. [DLX精确覆盖] hdu 3663 Power Stations

    题意: 给你n.m.d,代表有n个城市.m条城市之间的关系,每一个城市要在日后d天内都有电. 对于每一个城市,都有一个发电站,每一个发电站能够在[a,b]的每一个连续子区间内发电. x城市发电了.他相 ...

  3. 【HDU 3663】 Power Stations

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=3663 [算法] 先建图,然后用Dancing Links求解精确覆盖,即可 [代码] #inclu ...

  4. HDU 3909 DLX

    http://blog.csdn.net/sr_19930829/article/details/39756513 http://www.kuangbin.net/archives/hdu4069-d ...

  5. hdu 3111 DLX解数独

    思路:裸的DLX解数独.关键是建图,感觉还不如写个dfs直接,DLX写这个的代码很烦. #include<set> #include<map> #include<cmat ...

  6. hdu 2295 DLX

    思路:裸的DLX重复覆盖 #include<set> #include<cmath> #include<queue> #include<cstdio> ...

  7. hdu 3656 DLX

    思路:二分枚举建边,用DLX判断是否满足. #include<set> #include<cmath> #include<queue> #include<cs ...

  8. HDU 2828 DLX搜索

    Lamp Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  9. (中等) HDU 3335 , DLX+重复覆盖。

    Description As we know,the fzu AekdyCoin is famous of math,especially in the field of number theory. ...

随机推荐

  1. Fragment实现底部选项卡切换效果

    现在很多APP的样式都是底部选项卡做为首页的,实现这样的效果,我们一般有这样几种方式,第一,最屌丝的做法,我直接自定义选项卡视图,通过监听选项卡视图,逻辑控制内容页的切换,这样做的想法一般是反正这几个 ...

  2. 关于WebPlayer Sandbox的小节

    不可以像其他build target一样读写I/O 不可以call一些private或者internal methord 只要在一个top level的domain下可以不需要xml dmain po ...

  3. 初始化css代码需要注意的

    (从已经死了一次又一次终于挂掉的百度空间人工抢救出来的,发表日期 2014-05-06) 写在所有css代码之前,对网页中所有同类元素的一个样式规则代码或者一些基础性公用元素的样式规则代码. 1.空白 ...

  4. mybatis 注解快速上手

    一.mybatis 简单注解 关键注解词 : @Insert : 插入sql , 和xml insert sql语法完全一样 @Select : 查询sql, 和xml select sql语法完全一 ...

  5. 电子图书的编目和OPAC揭示

    摘  要  步入数字图书馆时代,电子资源日益增多,尤其在高校图书馆更加迅猛,怎样将图书馆的电子资源尽可能地整合在OPAC系统的检索功能里,以便更加简便.直观地利用,电子图书的编目已成为重要研究课题.本 ...

  6. asp.net架构基础知识--页面以及全局事件

    1.asp.net的请求过程,以及对应的处理请求的dll客户的请求页面由aspnet_isapi.dll这个动态连接库来处理,把请求的aspx文件发送给CLR进行编译执行,然后把Html流返回给浏览器 ...

  7. PS-添加前景色

    alt+Delete是填充前景色,即ps左边两个颜色块,前面的那个 ctrl+delete填充背景色

  8. AnimImageView

    https://github.com/eltld/AnimImageView

  9. HTML之一 符号实体

    符号实体和”语言代码“以及”字符集“无关.

  10. smartPtr指针的实现

    编写一个智能指针类.智能指针是一种数据类型,一般用模板实现,模拟指针行为的同时还提供自动来及回收机制.它会自动记录SmartPointer<T*>对象的引用计数,一旦T类型对象的引用计数为 ...