Dancing Links X 舞蹈链。

实质为用循环十字链在图上将所有“1”的位置链起来

构造较为巧妙,且极易理解,本题为 DLX 模板(精确覆盖问题)

DLX 算法的题目做法一般为将所求方案转化为行号,将限制条件转化为列号

然后 dfs 暴力枚举,用循环十字链优化

/*
Finished at 12:14 on 2024.4.5
*/
#include <bits/stdc++.h> using namespace std; const int N = 510, M = 250510; int n, m;
int a[N][N];
int row[M], col[M];
//row为每个点所在行号,col为每个点所在列号
int cnt, s[N], h[N];
//cnt为给每个链上的点的编号
//s表示某一列上所建链表点个数
//h为每一行的列表头
int u[M], d[M], l[M], r[M];
//u, d, l, r分别表示某个链表点上下左右所连的
int res[N];
//所选行号 void init() //初始化第0行的链表头
{
for (int i = 0; i <= m; i ++ )
u[i] = d[i] = i, l[i] = i - 1, r[i] = i + 1; //初始化左右,上下还没点,所以指向自己
l[0] = m, r[m] = 0, cnt = m; //处理剩下的0,m点
} void link(int x, int y)
{
s[y] ++ ;
cnt ++ ;
row[cnt] = x, col[cnt] = y;
u[cnt] = y;
d[cnt] = d[y]; //可类比链表,正常加即可
u[d[y]] = cnt;
d[y] = cnt;
if (!h[x]) h[x] = l[cnt] = r[cnt] = cnt; //本行无链表点,则加进去
else
{
l[cnt] = l[h[x]];
r[cnt] = h[x]; //正常双向链表加
r[l[h[x]]] = cnt;
l[h[x]] = cnt;
}
} void remove(int x)
{
r[l[x]] = r[x], l[r[x]] = l[x];
for (int i = d[x]; i != x; i = d[i]) //向下,向右删除每个点
for (int j = r[i]; j != i; j = r[j])
u[d[j]] = u[j], d[u[j]] = d[j], s[col[j]] -- ;
} void resume(int x)
{
r[l[x]] = x, l[r[x]] = x;
for (int i = u[x]; i != x; i = u[i]) //向上,向左恢复每个点
for (int j = l[i]; j != i; j = l[j])
u[d[j]] = j, d[u[j]] = j, s[col[j]] ++ ;
} bool dance(int depth)
{
if (r[0] == 0)
{
for (int i = 0; i < depth; i ++ ) cout << res[i] << ' ';
cout << '\n'; //第0行删完了
return true;
} int y = r[0];
for (int i = r[0]; i; i = r[i]) //优先找1少的
if (s[y] > s[i]) y = i; remove(y);
for (int i = d[y]; i != y; i = d[i])
{
res[depth] = row[i];
for (int j = r[i]; j != i; j = r[j]) remove(col[j]);
if (dance(depth + 1)) return true; //暴力枚举
for (int j = l[i]; j != i; j = l[j]) resume(col[j]);
}
resume(y); return false;
} int main()
{
cin >> n >> m;
for (int i = 1; i <= n; i ++ )
for (int j = 1; j <= m; j ++ )
cin >> a[i][j]; init();
for (int i = 1; i <= n; i ++ )
for (int j = 1; j <= m; j ++ )
if (a[i][j]) link(i, j); //1位置加点 if (!dance(0)) cout << "No Solution!\n"; return 0;
}

算法学习-Dancing Links X的更多相关文章

  1. 算法帖——用舞蹈链算法(Dancing Links)求解俄罗斯方块覆盖问题

    问题的提出:如下图,用13块俄罗斯方块覆盖8*8的正方形.如何用计算机求解? 解决这类问题的方法不一而足,然而核心思想都是穷举法,不同的方法仅仅是对穷举法进行了优化 用13块不同形状的俄罗斯方块(每个 ...

  2. Dancing Links X 学习笔记

    \(\\\) Definitions 双向链表:记录前后两个指针的链表,每个顺序关系都有双向的指针维护. \(Dancing\ Links\):双向十字循环链表,建立在二维关系上,每个元素记录上下左右 ...

  3. 跳跃的舞者,舞蹈链(Dancing Links)算法——求解精确覆盖问题

    精确覆盖问题的定义:给定一个由0-1组成的矩阵,是否能找到一个行的集合,使得集合中每一列都恰好包含一个1 例如:如下的矩阵 就包含了这样一个集合(第1.4.5行) 如何利用给定的矩阵求出相应的行的集合 ...

  4. 算法实践——舞蹈链(Dancing Links)算法求解数独

    在“跳跃的舞者,舞蹈链(Dancing Links)算法——求解精确覆盖问题”一文中介绍了舞蹈链(Dancing Links)算法求解精确覆盖问题. 本文介绍该算法的实际运用,利用舞蹈链(Dancin ...

  5. 浅入 dancing links x(舞蹈链算法)

    abastract:利用dancing links 解决精确覆盖问题,例如数独,n皇后问题:以及重复覆盖问题. 要学习dacning links 算法,首先要先了解该算法适用的问题,精确覆盖问题和重复 ...

  6. Dancing Links算法(舞蹈链)

    原文链接:跳跃的舞者,舞蹈链(Dancing Links)算法——求解精确覆盖问题 作者:万仓一黍 出处:http://grenet.cnblogs.com/ 本文版权归作者和博客园共有,欢迎转载,但 ...

  7. 转载 - 算法实践——舞蹈链(Dancing Links)算法求解数独

    出处:http://www.cnblogs.com/grenet/p/3163550.html 在“跳跃的舞者,舞蹈链(Dancing Links)算法——求解精确覆盖问题”一文中介绍了舞蹈链(Dan ...

  8. 转载 - 跳跃的舞者,舞蹈链(Dancing Links)算法——求解精确覆盖问题

    出处:http://www.cnblogs.com/grenet/p/3145800.html 精确覆盖问题的定义:给定一个由0-1组成的矩阵,是否能找到一个行的集合,使得集合中每一列都恰好包含一个1 ...

  9. [HDU1017]Exact cover[DLX][Dancing Links详解][注释例程学习法]

    Dancing Links解决Exact Cover问题. 用到了循环双向十字链表. dfs. 论文一知半解地看了一遍,搜出一篇AC的源码,用注释的方法帮助理解. HIT ACM 感谢源码po主.链接 ...

  10. Dancing Links 学习笔记

    Dancing Links 本周的AI引论作业布置了一道数独 加了奇怪剪枝仍然TLE的Candy?不得不去学了dlx dlxnb! Exact cover 设全集X,X的若干子集的集合为S.精确覆盖是 ...

随机推荐

  1. 操作系统|C语言模拟实现首次适应和最佳适应两种内存分配算法以及内存回收

    两种算法 首次适应 首次适应算法从空闲分区表的第一个表目起查找该表,把最先能够满足要求的空闲区分配给作业,这种方法目的在于减少查找时间.为适应这种算法,空闲分区表(空闲区链)中的空闲分区要按地址由低到 ...

  2. Vue 打包后自定义样式无法覆盖elementUI组件原有样式问题

    Vue 打包后自定义样式无法覆盖elementUI组件原有样式问题   by:授客 QQ:1033553122   开发环境   Win 10   node-v10.15.3-x64.msi 下载地址 ...

  3. AI时代你应聚焦的领域在哪里

    1. 每个人都应该拥抱AI 随着AI的飞速发展,把我们带到了一个全新的时代.在这个时代,AI将逐步渗透到各个方面,比如:自动驾驶.智能家居.医疗诊断.大模型等等.每个人都应该积极拥抱AI,让AI给我们 ...

  4. Beizer。。。。。

    <html> <head>AS</head> <script> var cvs; var context; //context.fill();//填充 ...

  5. 【译】宣布三项新的高级 Visual Studio 订阅者福利

    Visual Studio 订阅(无论是专业版还是企业版)提供的不仅仅是软件使用权:这是一个全面的工具包,旨在显著提高您的开发能力和职业发展.这些订阅每年可以为您节省数千美元,提供各种服务,从每月用于 ...

  6. SEO初学指南之关键词研究(1) - 入门

    Hi,我是听风. 第一篇给大家科普了什么是SEO以及搜索引擎的原理,这篇文章我们正式进入关键词研究的章节. 本片文章将学习什么是关键词以及如何挑选符合预期的关键词. 一.什么是SEO关键词 简单来说就 ...

  7. 一张图看懂 SQL 的各种 JOIN 用法(含数据集和韦恩图)

  8. RHCA rh442 009 磁盘算法 RAID相关 磁盘压力测试

    磁盘 一个数据在磁盘A位置,一个数据在磁盘B位置,他们如果隔着很远.这对磁盘来说性能很差 (机械盘,磁头来回移动) 一个数据写进来,他会把数据放到缓存中,经过磁盘调度算法来调度,最后写到硬盘 io读写 ...

  9. 2023年人工智能发展现状报告:State of AI Report 2023

    链接: https://www.stateof.ai/ ================================ Now in its sixth year, the State of AI ...

  10. Git报错解决:OpenSSL SSL_read: Connection was reset, errno 10054 错误解决

    1.背景 最近因项目上需要,想借鉴一下spring里面的一下架构设计,在拉取spring源码是报错如下: 初步判定,估计是访问国外的网站,网速受限的原因..... 2.解决方案 打开Git命令页面,执 ...