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 ...
随机推荐
- Android/IOS 微信及浏览器(h5)中唤起本地APP,唤起浮层,然后用外部浏览器打开唤起某本地APP
1 前言 微信点击链接,点击唤起某APP,在微信点开,默认是微信浏览器,点击button唤起,则会先提示浮层,然后用外部浏览器打开即可. 作为记录使用. 2 代码 相关源码如下: html: < ...
- django配置发送邮箱
该邮箱配置后台发送邮箱验证使用 settings内配置 # 服务器地址 EMAIL_HOST = 'smtp.163.com' # 端口,邮箱默认动态端口 25 EMAIL_PORT = 25 # 邮 ...
- Ajax 执行顺序
jQuery中各个事件执行顺序如下: 1.ajaxStart(全局事件) 2.beforeSend 3.ajaxSend(全局事件) 4.success 5.ajaxSuccess(全局事件) 6.e ...
- python-基于UDP通信的套接字,socketserver模块的使用
一.基于UDP协议通信的套接字 udp是没有链接的,所以先启动哪一端都不会报错 import socket server=socket.socket(socket.AF_INET,socket.SOC ...
- python-re模块和subprocess模块
一.re模块 re中文为正则表达式,是字符串处理的常用工具,通常用来检索和替换符合某个模式的文本. 注:要搜索的模式和字符串都可以是unicode字符串(str)和8位字符串(bytes),但是不能将 ...
- hashtable——散列表
2018-11-01 散列表---哈希表基于快速存取,时间换空间一种基于线性数组的线性表,不过元素之间并非紧密排列 散列函数--通过函数,有key关键码计算地址(相当于数组下标),函数尽可能使元素均匀 ...
- hive学习01词频统计
词频统计 #创建表,只有一列,列名line create table word_count ( line string) row format delimited fields terminated ...
- swift 实践- 14 -- UIScrollView
import UIKit class ViewController: UIViewController ,UIScrollViewDelegate{ override func viewDidLoad ...
- JUnit-三角形判断测试
添加工具 1.添加JUnit测试工具: 使用eclipse自带的JUnit或者下载相关包.使用方式如下: 新建一个项目后,点击next出现以下界面: 选择添加JUnit 选择完成出现以下目录文件: p ...
- Java 开源博客 Solo 2.5.0 发布
Java 开源博客 Solo 2.5.0 发布 Solo 是一款一个命令就能搭建好的 Java 开源博客系统,如果你想开个独立博客,请一定不要错过! 2.5.0 版本主要支持了 Markdown/JS ...