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 ...
随机推荐
- (原)Ubuntu16中编译caffe
转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5797526.html 参考网址: http://caffe.berkeleyvision.org/in ...
- jira汉化
https://translations.atlassian.com/dashboard/dashboard 下载汉化jar文件,在jira中上传插件,系统设置中文即可 LOFTER:我们的故事 ...
- jquery 源码分析
想给自己一个任务,接下来要分析jquery源码,然后按照jquery的思想打造一个适合webkit的类jquery微框架,一切从模仿起!
- [C++程序设计]基于对象的程序设计 基于对象的程序设计
1. 面向对象分析(object oriented analysis,OOA)2. 面向对象设计(object oriented design,OOD)3. 面向对象编程(object oriente ...
- 基于VMware的eCos应用程序测试(hello wold)
(1)脚本配置ecosconfig new pccdl_component CYG_HAL_STARTUP { # Flavor: data # No user value, uncomment th ...
- 关于bootstrap列偏移的两种方式
第一种方式: <div class="col-md-2 col-md-offset-9"> <input type="text" class= ...
- dreamweaver批量去除空格,空行
制作网店的时候,发现有空行,或者空格.如果数量比较少,可以手动清除.如果多的话,可以使用dreamweaver批量去除.方法如下: 第一步,用正则表达式删除所有空白行(其实这一步不一定要做,我只是为了 ...
- C++ Primer day 01
1.标准输入与输出 #include<iostream> int main(){ int v1,v2; std::cout<<"Enter two numbers:& ...
- QAction系列详解
QAction系列详解 一.QAction类详解 [详细描述] QAction类提供了抽象的用户界面action,这些action可以被放置在窗口部件中. 应用程序可以通过菜单,工具栏按 ...
- HDU4762(JAVA大数)
Cut the Cake Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...