UVA-818 dfs + 位运算
暴力枚举一些圆环,将这些圆环解开,看能否成为单链。判断单链的三个条件:
- 除了这些删除的圆环之外,其他圆环还连接着的圆环不能超过两个。
- 剩下的环没有连成圈。
- 剩下的圆环共分成m堆,每堆之间无连接,m必须小于等于解开的圆环数+1。
最多有15个环,可以用二进制保存。
AC代码:
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cstdlib>
using namespace std;
#define pos(x) (1 << ((x) - 1))
const int maxn = 20;
int g[maxn], vis[maxn], d[maxn];
int n;
int bit(int x) {
int cnt = 0;
while(x > 0) {
if(x & 1) ++cnt;
x >>= 1;
}
return cnt;
}
bool dfs(int u, int pre){
vis[u] = -1;
int m = g[u];
for(int i = 1; i <= n; ++i){
if(d[i] || i == pre || !(pos(i) & m)) continue;
if(vis[i] == -1) return false;
if(!vis[i] && !dfs(i, u)) return false;
}
vis[u] = 1;
return true;
}
bool solve(int p){
memset(vis, 0, sizeof(vis));
memset(d, 0, sizeof(d));
for(int i = 1; i <= n; ++i){
if(pos(i) & p) d[i] = 1;
}
for(int i = 1; i <= n; ++i) {
if(d[i]) continue;
int x = 0;
for(int j = 1; j <= n; ++j){
if(!d[j] && pos(j) & g[i]) ++x;
}
if(x > 2) return false;
}
int cnt = 0; //联通块数量
for(int i = 1; i <= n; ++i){
if(vis[i] || d[i]) continue;
if(!dfs(i, -1)) return false; //有环
++cnt;
}
if(cnt > bit(p) + 1) return false; //大于独立的圆环数,无法连接
return true;
}
int main() {
int kase = 0;
while(scanf("%d", &n) == 1 && n){
int a, b;
memset(g, 0, sizeof(g));
while(1) {
scanf("%d%d", &a, &b);
if(a == -1 && b == -1) break;
g[a] |= (1 << (b - 1)); //a can reach b
g[b] |= (1 << (a - 1)); //b can reach a
}
int total = 1 << n;
int ans = 1 << 30;
for(int i = 0; i < total; ++i) {
if(bit(i) >= ans) continue;
if(solve(i)) {
ans =min(ans, bit(i));
}
}
printf("Set %d: Minimum links to open is %d\n", ++kase, ans);
}
return 0;
}
如有不当之处欢迎指出!
UVA-818 dfs + 位运算的更多相关文章
- uva 818 (位运算 + 判环)
Cutting Chains What a find! Anna Locke has just bought several links of chain some of which may be ...
- UVa 818Cutting Chains (暴力dfs+位运算+二进制法)
题意:有 n 个圆环,其中有一些已经扣在一起了,现在要打开尽量少的环,使所有的环可以组成一条链. 析:刚开始看的时候,确实是不会啊....现在有点思路,但是还是差一点,方法也不够好,最后还是参考了网上 ...
- 数独求解问题(DFS+位运算优化)
In the game of Sudoku, you are given a large 9 × 9 grid divided into smaller 3 × 3 subgrids. For exa ...
- UVA 690 PipelineScheduling 位运算+dfs+剪枝
一开始最容易想到间隔最多为n,但是结点还是太多了,需要优化. 预处理:预判一下并保存下一个可以放的位置距离之前的距离.这样可以减少很多判断. 最优化剪枝:如果当前长度+剩下没放的程序*最短间隔如果大于 ...
- POJ 1164 城堡问题【DFS/位运算/种子填充法/染色法】
1 2 3 4 5 6 7 ############################# 1 # | # | # | | # #####---#####---#---#####---# 2 # # | ...
- UVA 11464 暴力+位运算 ***
题意:给你一个 n * n 的 01 矩阵,现在你的任务是将这个矩阵中尽量少的 0 转化为 1 ,使得每个数的上下左右四个相邻的数加起来是偶数.求最少的转化个数. 新风格代码 lrj书上说的很清楚了, ...
- uva 10718 Bit Mask (位运算)
uva 10718 Bit Mask (位运算) Problem A Bit Mask Time Limit 1 Second In bit-wise expression, mask is a ...
- 【位运算DFS/DLX】【HDU1426】【数独】
题意:标准的一道数独题 DFS做法: 将横纵九宫格里的数字用位运算状态压缩,且可以通过逻辑或来确定总共有哪些数字被选择了,很方便也很快,代码如下 #include <cstdio> #in ...
- UVA 10718 Bit Mask 贪心+位运算
题意:给出一个数N,下限L上限U,在[L,U]里面找一个整数,使得N|M最大,且让M最小. 很明显用贪心,用位运算搞了半天,样例过了后还是WA,没考虑清楚... 然后网上翻到了一个人家位运算一句话解决 ...
随机推荐
- 一张表搞清楚php is_null、empty、isset的区别
isset 判断变量是否已存在 empty 判断变量是否为空或为0 is_null 判断变量是否为NULL 变量 empty is_null isset $a="" true fa ...
- 利用JS判断浏览器种类
现在浏览器很多,写代码的时候常常存在兼容性问题,所以判断用户使用的浏览器很重要.userAgent带有浏览器的种类及版本号等信息,所以可以通过userAgent属性来判断.一些冷门的浏览器,可以通过打 ...
- servlet 监听器分类
http://blog.csdn.net/cxg200888/article/details/77894842
- Spring MVC (JDK8+Tomcat8)
1 Spring MVC概述 Spring MVC是Spring为表现层提供的基于MVC设计理念的优秀的web框架,是目前最主流的MVC框架之一. Spring3.0后全面超越Struts2,成为最优 ...
- mysql数据库表字段使用DESC等关键字报错及解决方法
<!-- desc是MySQL数据库的关键字,作为字段名直接使用会报错 --><sql id="Base_Column"> id,mol,ip,port,n ...
- MySQL数据库学习笔记----MySQL多表查询之外键、表连接、子查询、索引
本章主要内容: 一.外键 二.表连接 三.子查询 四.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复 ...
- convert图像格式批量转换
问题:利用GMT绘制生成了eps格式的图像,为了将图像插入到word中,且保持较高的分辨率,利用convert进行图像格式转换,将eps转换成tiff格式. code: $i ${name}.tif ...
- ssh免秘钥登录
简介 SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定:SSH 为建立在应用层基础上的安全协议.SSH 是目前较可靠,专为远程 ...
- ABP官方文档翻译 5.4 SwaggerUI集成
SwaggerUI集成 介绍 ASP.NET Core 安装Nuget包 配置 测试 ASP.NET 5.x 安装Nuget包 配置 测试 介绍 在它的网站上:“...使用Swagger可用的API, ...
- Django之wagtail安装及配置
安装指引原文地址:Http://docs.wagtail.io/en/v1.13.1 需要注意的几点: 指定端口启动服务:在项目根目录下 ,运行 python manage.py runserver ...