POJ3740 Easy Finding 舞蹈链 DLX
欢迎访问~原文出处——博客园-zhouzhendong
去博客园看该题解
题目
精确覆盖问题模板题
算法
DLX算法
代码
#include <cstring>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cmath>
using namespace std;
const int N=+,M=+;
struct X{
int L,R,U,D,Col,Row;
}p[N*M];
int n,m;
int g[N][M],C[M],cnt=;
bool flag=;
void Delete(int k){
p[p[k].R].L=p[k].L;
p[p[k].L].R=p[k].R;
for (int i=p[k].D;i!=k;i=p[i].D)
for (int j=p[i].R;j!=i;j=p[j].R){
C[p[j].Col]--;
p[p[j].U].D=p[j].D;
p[p[j].D].U=p[j].U;
}
}
void Reset(int k){
p[p[k].L].R=k;
p[p[k].R].L=k;
for (int i=p[k].U;i!=k;i=p[i].U)
for (int j=p[i].L;j!=i;j=p[j].L){
C[p[j].Col]++;
p[p[j].U].D=j;
p[p[j].D].U=j;
}
}
bool DLX(){
if (p[].R==)
return true;
int k=p[].R;
for (int i=p[k].R;i!=;i=p[i].R)
if (C[i]<C[k])
k=i;
Delete(k);
for (int i=p[k].D;i!=k;i=p[i].D){
for (int j=p[i].R;j!=i;j=p[j].R)
Delete(p[j].Col);
if (DLX())
return true;
for (int j=p[i].L;j!=i;j=p[j].L)
Reset(p[j].Col);
}
Reset(k);
return false;
}
int main(){
while (~scanf("%d%d",&n,&m)){
for (int i=;i<=n;i++)
for (int j=;j<=m;j++)
scanf("%d",&g[i][j]);
memset(p,,sizeof p);
memset(C,,sizeof C);
for (int i=;i<=m;i++)
p[i].L=i-,p[i].R=i+,p[i].U=p[i].D=i;
p[].L=m,p[m].R=,cnt=m;
for (int i=;i<=n;i++){
int first=cnt+;
for (int j=;j<=m;j++)
if (g[i][j]){
cnt++;
p[cnt].L=cnt-;
p[cnt].R=cnt+;
p[cnt].D=j;
p[p[j].U].D=cnt;
p[cnt].U=p[j].U;
p[j].U=cnt;
C[p[cnt].Col=j]++;
p[cnt].Row=i;
}
if (cnt>=first)
p[first].L=cnt,p[cnt].R=first;
}
if (DLX())
puts("Yes, I found it");
else
puts("It is impossible");
}
return ;
}
POJ3740 Easy Finding 舞蹈链 DLX的更多相关文章
- 舞蹈链 DLX
欢迎访问——该文出处-博客园-zhouzhendong 去博客园看该文章--传送门 舞蹈链是一个非常玄学的东西…… 问题模型 精确覆盖问题:在一个01矩阵中,是否可以选出一些行的集合,使得在这些行的集 ...
- [学习笔记] 舞蹈链(DLX)入门
"在一个全集\(X\)中若干子集的集合为\(S\),精确覆盖(\(\boldsymbol{Exact~Cover}\))是指,\(S\)的子集\(S*\),满足\(X\)中的每一个元素在\( ...
- luogu P4929 【模板】舞蹈链 DLX
LINK:舞蹈链 具体复杂度我也不知道 但是 搜索速度极快. 原因大概是因为 每次检索的时间少 有一定的剪枝. 花了2h大概了解了这个东西 吐槽一下题解根本看不懂 只能理解大概的想法 核心的链表不太懂 ...
- P4929-[模板]舞蹈链(DLX)
正题 题目链接:https://www.luogu.com.cn/problem/P4929 题目大意 \(n*m\)的矩形有\(0/1\),要求选出若干行使得每一列有且仅有一个\(1\). 解题思路 ...
- Vijos1755 靶形数独 Sudoku NOIP2009 提高组 T4 舞蹈链 DLX
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目(传送门) 题意概括 给出一个残缺的数独,求这个数独中所有的解法中的最大价值. 一个数独解法的价值之和为每个位置所填的数值 ...
- POJ3076 Sudoku 舞蹈链 DLX
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目(传送门) 题意概括 给出一个残缺的16*16数独,求解. 题解 DLX + 矩阵构建 (两个传送门) 学完这个之后,再 ...
- POJ3074 Sudoku 舞蹈链 DLX
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目(传送门) 题意概括 给出一个残缺的数独,求解. 题解 DLX + 矩阵构建 (两个传送门) 代码 #include & ...
- POJ2676 Sudoku 舞蹈链 DLX
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目(传送门) 题意概括 给出一个残缺的数独,求解.SPJ 题解 DLX + 矩阵构建 (两个传送门) 代码 #includ ...
- 关于用舞蹈链DLX算法求解数独的解析
欢迎访问——该文出处-博客园-zhouzhendong 去博客园看该文章--传送门 描述 在做DLX算法题中,经常会做到数独类型的题目,那么,如何求解数独类型的题目?其实,学了数独的构建方法,那么DL ...
随机推荐
- awk-for循环简单用法
文本: [root@VM_0_84_centos ~]# cat sshd.txt 1 2 3 4 5 6 7 8 9 循环打印上述文本 for 循环的固定格式 i=1设置i的初始变量 i< ...
- html<meta>标签
1. 定义说明 <meta>提供与页面有关的元数据,元数据是对数据的描述 <meta>总是位于<head></head>中 <meta>定义 ...
- 2018谷歌I/O开发者大会8大看点汇总 新品有哪些
2018谷歌I/O开发者大会8大看点汇总 新品有哪些美国科技媒体The Verge近日撰文,列举了在即将召开的2018年谷歌I/O开发者大会上的8大看点,包括Android P.人工智能等等. 以下为 ...
- Confluence 6 恢复一个站点有关使用站点导出为备份的说明
推荐使用生产备份策略.我们推荐你针对你的生产环境中使用的 Confluence 参考 Production Backup Strategy 页面中的内容进行备份和恢复(这个需要你备份你的数据库和 ho ...
- 使用 Jira 和 Confluence 6 在一起
这个过程是有趣的过程.请参考 Use Jira applications and Confluence together 文档来找到有关整合的相关内容,能够在后续的开发中更多的节省时间,以及你需要安装 ...
- 基于 Confluence 6 数据中心的 SAML 单点登录设置 SSL/TLS
请确定 SAML 授权是安全和私有的,你需要在你的应用程序中设置SSL/TLS. 请参考in the application. See Running Confluence Over SSL or H ...
- 【shell】两种字符串提取场景的实现
shell虽然比batch顺眼点儿,但还是老话,入门容易,精通难. 1.场景一是这样的,现有字符串的内容 name: tiger; age:18; location:china; 需求:提取每个属性的 ...
- 【JDK】JDK模块化(1)-为什么要模块化
Java9发布已经有一年了,跟Java8相比,从目录对比就看得出来差别相当大. 实际上Java9最大的变化就是JDK模块化(Modular). 那么,模块化的目的是什么呢? 官方的说法是: 之前版本的 ...
- gulp前端工程化教程
gulp npm install -g gulp-concat 文件打包 npm install -g gulp-rename 文件重命名 npm install -g gulp-imagemin 图 ...
- x学生管理系统(用中间件)-------基于FORM组件
目的:实现学生,老师,课程的增删改查 models.py from django.db import models # Create your models here. class UserInfo( ...