HDU 5727 - Necklace
题意:( 0 <= n <= 9 )
现在有n颗阴珠子和n颗阳珠子,将它们阴阳相间圆排列构成一个环,
已知有些阴珠子和阳珠子不能放在相邻的位置,否则这颗阳珠子就会失去功效,
输出最少失去能量的阳珠子数目
分析: 枚举 + 二分图匹配
先把阴珠放好,然后将阳珠插入空位中。
枚举阴珠摆放位置,将阳珠匹配到不影响两边阴珠的位置
这样 ans = min( n - 最大匹配数 )
注意:
n = 0 时 无法使用 next_permutation 函数!!
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int MAXN=;
int n, m, ans;
bool G[MAXN][MAXN], F[MAXN][MAXN], used[MAXN];
int Linker[MAXN];
int a[MAXN];
bool dfs(int u)
{
for(int v = ;v <= n; v++) {
if(G[u][v] && !used[v]) {
used[v] = ;
if(Linker[v]==-||dfs(Linker[v])) {
Linker[v] = u;
return ;
}
}
}
return ;
}
int Hungary(){//匈牙利
int res = ;
memset(Linker, -, sizeof(Linker));
for(int u = ; u <= n; u++){
memset(used, , sizeof(used));
if(dfs(u)) res++;
}
return res;
}
int main()
{
while(~scanf("%d%d",&n,&m))
{
memset(F,,sizeof(F));
for(int i=;i<=m;i++)
{
int a,b;
scanf("%d%d",&a,&b);
F[a][b]=;
}
ans=;
for(int i=;i<=n;i++) a[i]=i;
if(n == ) { puts(""); continue; }//此时无法全排列!!!
do//全排列
{
memset(G,,sizeof(G));
for(int i = ;i <= n;i++)
{
int l = a[i],r = (i == n ? a[] : a[i+]);
for(int u = ;u <= n; u++)
if( !F[u][l] && !F[u][r])//不影响两边
G[u][i]=;
}
ans=min(n - Hungary(), ans);
} while (next_permutation(a + ,a + n + ));//因为是环,第一点不用动
printf("%d\n",ans);
}
}
HDU 5727 - Necklace的更多相关文章
- hdu 5727 Necklace dfs+二分图匹配
Necklace/center> 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5727 Description SJX has 2*N mag ...
- HDU 5727 - Necklace - [全排列+二分图匹配][Hopcroft-Karp算法模板]
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5727 Problem DescriptionSJX has 2*N magic gems. ...
- HDU 5727 Necklace(二分图匹配)
[题目链接]http://acm.hdu.edu.cn/showproblem.php?pid=5727 [题目大意] 现在有n颗阴珠子和n颗阳珠子,将它们阴阳相间圆排列构成一个环,已知有些阴珠子和阳 ...
- HDU 5727 Necklace(全排列+二分图匹配)
http://acm.split.hdu.edu.cn/showproblem.php?pid=5727 题意:现在有n个阳珠子和n个阴珠子,现在要把它们串成项链,要求是阴阳珠子间隔串,但是有些阴阳珠 ...
- TTTTTTTTTTTTTTTT hdu 5727 Necklace 阴阳珠 二分图匹配+暴力全排列
Necklace Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Su ...
- HDU 5727 Necklace 环排+二分图匹配
这是从山东大学巨巨那里学来的做法 枚举下黑色球的排列总数是8!,然后八个白球可选的位置与左右两个黑球存不存在关系建图就行 这是原话,具体一点,每次生成环排,只有互不影响的才连边 最后:注重一点,n个数 ...
- hdu 5727 Necklace 二分图匹配
题目链接 给2*n个珠子, n<=9, n个阴n个阳. 然后将它们弄成一个环, 阴阳交替.现在给你m个关系, 每个关系给出a, b. 如果阳a和阴b挨着, 那么a就会变暗. 问你最小变暗几个阳. ...
- HDU 5727 Necklace ( 2016多校、二分图匹配 )
题目链接 题意 : 给出 2*N 颗珠子.有 N 颗是阴的.有 N 颗是阳的.现在要把阴阳珠子串成一个环状的项链.而且要求珠子的放置方式必须的阴阳相间的.然后给出你 M 个限制关系.格式为 ( A.B ...
- hdu 5727 二分图+环排列
Necklace Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Su ...
随机推荐
- lucene.net 3.0.3、结合盘古分词进行搜索的小例子(转)
lucene.net 3.0.3.结合盘古分词进行搜索的小例子(分页功能) 添加:2013-12-25 更新:2013-12-26 新增分页功能. 更新:2013-12-27 新增按分类查询功能, ...
- (原)安装windows8.1和ubuntu16双系统及相互访问磁盘
转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5638232.html 参考网址: http://jingyan.baidu.com/article/f ...
- 再谈c++中的引用
在<从汇编看c++的引用和指针>一文中,虽然谈到了引用,但是只是为了将两者进行比较.这里将对引用做进一步的分析. 1 引用的实现方式 在介绍有关引用的c++书中,很多都说引用只是其引用变量 ...
- Windows7上FTP服务器建立
1. FTP服务器建立 注意:千万不能使用FTP和ftp建立用户,否则无法登陆ftp服务器. 1.1本地机器上创建一个用户 这个用户是用来登录到FTP的.我的电脑右键->管理->本地用户和 ...
- python2 ----函数字典的使用
问题背景: 最近在用python2为sublime2写一个插件,其中有一个命令功能,就是输入不同的命令调用不同的函数,但是python不支持switch,只用ifelse的话感觉特别的low而且明显不 ...
- c++基础五个题(三)
一.一个对象访问普通函数和虚函数的时候,哪一个更快? 访问普通函数更快,因为普通成员函数在编译阶段已经被确定,因此在访问时直接调用对应地址的函数,而虚函数在调用时,需要首先在虚函数表中查找虚函数所在的 ...
- js 创建对象
1.工厂模式 function createPerson(name, age, job) { var o = new Object(); o.name = name; o.age = age; o.j ...
- Html辅助方法 之 Form表单标签
一.Html.BeginForm <form>标签 //视图代码@using (Html.BeginForm("search", "home", F ...
- logstash nginx 访问日志
log_format main '$remote_addr [$time_local] "$request" ' '$request_body $status $body_byte ...
- Linux系统编程(8)—— 进程之进程控制函数fork
fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事. 一个进程调用fork()函数后,系统先 ...