四分图匹配
题目描述
一天晚上,zzh 在做梦,忽然梦见了她。
见到她,zzh 也不去看她,只顾低头自语……
“噫,OI 这个东西,真是无奇不有。”
“嘿,你又学了什么?”
“嗯,学到了一种算法,”zzh 装作很神秘的样子,“在生活中有着广泛的应
用,这个算法由匈牙利数学家 Edmonds 于 1965 年提出……”
“哦,那是二分图匹配?”
“咦,你不学 OI,你怎么知道?”
她微微一笑。
“哼!你又不学 OI,你说的什么二分图匹配,只是道听途说而已吧?”
“既然你这么说,那就给你出一道题。听好咯!”
定义四分图,为能将其点集分成四部分,各部分内部没有边的特殊无向图。
定义环的长度,为环中的边数。
定义四分图的一个匹配,为在四分图的边集中提取出一个子集,使得集合中
的边连起来之后,能够构成若干(设为 K)个长度为四的环,每个点最多属于一
个环,并且环上的四个顶点恰好依次取自四分图的四个子点集。其中 K 定义为
四分图的匹配数。
定义四分图的最大匹配,为匹配数最大的匹配方案。
定义四分图的两个匹配是不同的,仅当至少有一条边在一个匹配中是匹配边,
在另一个匹配中不是匹配边。
定义四分图的最大匹配方案数 S,为四分图最大匹配集合的元素个数。
现在对于一张的四分图,要求求其最大匹配数,与其最大匹配方案数。
图的总点数、总边数均不超过 100。
zzh 听完,好不容易记住了定义,结果发现并不会做……于是他只好低下头:
“唉,这题太难了……”
“好吧,那我把这题弱化一下,我把图改成一张特殊的四分图。”
记四个点集分别为 A、B、C、D,给出的四分图按如下规则构造:
点编号(均为整数)范围:
A 集:1..N B 集:1..N C 集:1..2N-1 D 集:1..2N-1
连边情况:
对于所有满足 1≤i,j≤N 的数字对,均有边
A[i]------------------B[j]
| |
C[N+i-j]------D[i+j-1] “既然图已经满足特殊性了,那么我也应该拿掉一个限制。”她笑着说,“我
把边数不超过 100 这个条件去掉。点数的范围就不更改了。”
zzh 又开始苦思冥想,他想了好多好多,想了好久好久,但是最终……
“我不会做……”zzh 低下了头,声音压得很低很低。
“服不服?”
“不服!”
“好吧,看你不服,我把问题再弱化一下!我把点数限制设为不超过 7,这
下,你总应该能做出来了吧?”
zzh 又想了好久好久,结果发现仍然是不会做……这时,床头的闹铃划破了
梦的喧嚣……
现在,zzh 只想问问大家,这题弱化版的弱化版,到底怎么做?
输入描述
一行一个数字,N。
输出描述
第一行输出 K 的最大值,第二行输出 S。
输入样例
2
输出样例
2
4
数据范围
测试点编号 N=3 4 5 6 7
 
sol:打表好题。。。
#include <cstdio>

bool ab[][],ac[][],bd[][],cd[][];
int e[];
int i,j,n;
long long s; inline void dfs(int x,int bb,int cc,int dd)
{
if (x==n+)
s++;
else
{
for (int b=bb;b!=;b=b-(b&(-b)))
{
int i=e[b&(-b)];
if (ab[x][i])
for (int c=cc;c!=;c=c-(c&(-c)))
{
int j=e[c&(-c)];
if (ac[x][j])
for (int d=dd;d!=;d=d-(d&(-d)))
{
int k=e[d&(-d)];
if ((bd[i][k]) && (cd[j][k]))
dfs(x+,bb^(<<(i-)),cc^(<<(j-)),dd^(<<(k-)));
}
}
}
}
return;
} int main()
{
scanf("%d",&n);
for (i=;i<=n;i++)
for (j=;j<=n;j++)
ab[i][j]=ac[i][n+i-j]=bd[j][i+j-]=cd[n+i-j][i+j-]=true;
for (i=,j=;j<=*n;i=i<<,j++)
e[i]=j;
dfs(,(<<n)-,(<<(*n-))-,(<<(*n-))-);
printf("%d\n%lld\n",n,s);
return ;
}

詹神打表代码

#include <bits/stdc++.h>
using namespace std;
typedef int ll;
inline ll read()
{
ll s=; bool f=; char ch=' ';
while(!isdigit(ch)) {f|=(ch=='-'); ch=getchar();}
while(isdigit(ch)) {s=(s<<)+(s<<)+(ch^); ch=getchar();}
return (f)?(-s):(s);
}
#define R(x) x=read()
inline void write(ll x)
{
if(x<) {putchar('-'); x=-x;}
if(x<) {putchar(x+''); return;}
write(x/); putchar((x%)+'');
}
#define W(x) write(x),putchar(' ')
#define Wl(x) write(x),putchar('\n')
int n;
int main()
{
freopen("quadripartite.in","r",stdin);
freopen("quadripartite.out","w",stdout);
R(n);
Wl(n);
if(n==) puts("");
else if(n==) puts("");
else if(n==) puts("");
else if(n==) puts("");
else puts("");
return ;
}

7.26T1四分图匹配的更多相关文章

  1. SQL中常用模糊查询的四种匹配模式&&正则表达式

    执行数据库查询时,有完整查询和模糊查询之分.一般模糊语句如下:SELECT 字段 FROM 表 WHERE 某字段 Like 条件 其中关于条件,SQL提供了四种匹配模式:1.%:表示任意0个或多个字 ...

  2. UVaLive 7375 Hilbert Sort (递归,四分图,模拟)

    题意:告诉你一条希尔伯特曲线的大小,然后给你n 个人,及n 个人的坐标,你的起点是左下角,终点是右下角,按照希尔伯特的曲线去走,按照这个顺序给n个人排序, 按顺序输出每个人的名字! 析:这就是一个四分 ...

  3. UVA - 297Quadtrees(四分图)

    Quadtrees Time Limit: 3000MS   Memory Limit: Unknown   64bit IO Format: %lld & %llu Submit Statu ...

  4. SQL模糊查询条件的四种匹配模式

    执行数据库查询时,有完整查询和模糊查询之分. 一般模糊语句格式如下: SELECT 字段 FROM 表 WHERE 某字段 LIKE 条件 其中关于条件,SQL提供了四种匹配模式: 1.% :表示任意 ...

  5. spring cloud: zuul(四): 正则表达式匹配其他微服务(给其他微服务加版本号)

    spring cloud: zuul(四): 正则表达式匹配其他微服务(给其他微服务加版本号) 比如我原来有,spring-boot-user微服务,后台进行迭代更新,另外其了一个微服务: sprin ...

  6. SQL模糊查询的四种匹配模式

    执行数据库查询时,有完整查询和模糊查询之分,一般模糊语句如下: SELECT 字段 FROM 表 WHERE 某字段 Like 条件 一.四种匹配模式 关于条件,SQL提供了四种匹配模式: 1.% 表 ...

  7. SQL 模糊查询条件的四种匹配模式

    转: 执行数据库查询时,有完整查询和模糊查询之分. 一般模糊语句格式如下: SELECT 字段 FROM 表 WHERE 某字段 LIKE 条件; 其中,关于条件,SQL提供了四种匹配模式: 1.%: ...

  8. QL Server 中四种匹配符的含义

    SQL中我们会见到很多的匹配符,下面解释一下 % 代表零个或者多个任意字符 _ 代表一个任意字符 [] 指定范围内的任意单个字符 [^] 不在指定范围内的任意单个字符 带有匹配符的字符串必须使用引号引 ...

  9. HDU2819-Swap-二分图匹配

    把矩阵上的1建成边,把边建成点 然后跑一个二分图匹配,就找到了主对角线的元素,之后排个序就可以了 /*------------------------------------------------- ...

随机推荐

  1. redis键的排序操作

    命令名称:sort 语法:sort key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC|DESC] [ ...

  2. 在论坛中出现的比较难的sql问题:9(触发器专题 插入数据自动更新表数据)

    原文:在论坛中出现的比较难的sql问题:9(触发器专题 插入数据自动更新表数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所 ...

  3. tf 2.0

    tf.function和Autograph使用指南-Part 1 "Keras之父发声:TF 2.0 + Keras 深度学习必知的12件事" Effective TensorFl ...

  4. php实现命令行里输出带颜色文字

    今天执行composer的时候看到命令窗口出现的提示里面有的关键性部分带有颜色,于是很好奇研究了一下,在这里记录下来 其实在命令行输出带颜色字体主要是使用的 ANSI 转义字符实现的,我们先看个例子: ...

  5. springload热更新的优缺点

    java开发web应用没有.net的方便快捷, 原因是传统开发模式下新增修改代码后要查看效果, 一般要重启应用, 导致浪费了许多无谓的时间,没有.net的高效, 任意更新文件实时生效. 但是有个叫sp ...

  6. 为什么JAVA线程中没有Running状态?

    面试官问:为什么 Java 线程没有 Running 状态?我懵了 —— 转  芋道源码 什么是 RUNNABLE? 与传统的ready状态的区别 与传统的running状态的区别 当I/O阻塞时 如 ...

  7. HCIP DAY2

    OSPF协议的基本特点: 支持无类域间路由(CIDR) vlsm NA 无路由自环 收敛速度快 使用IP组播放收发协议数据 支持多条等值路由 静态路由 动态路由 等价路由 浮动路由 支持协议报文的认证 ...

  8. 【Intel 汇编】ELF文件

    ELF文件格式是一个开放标准,各种UNIX系统的可执行文件都采用ELF格式,它有三种不同的类型: 可重定位的目标文件(Relocatable,或者Object File) 可执行文件(Executab ...

  9. 剑指Offer编程题(python)——链表

    1.从尾到头打印链表 #输入一个链表,按链表值从尾到头的顺序返回一个ArrayList.class ListNode: def __init__(self, x): self.val = x self ...

  10. 哲学家就餐问题 C语言实现

    场景: 原版的故事里有五个哲学家(不过我们写的程序可以有N个哲学家),这些哲学家们只做两件事--思考和吃饭,他们思考的时候不需要任何共享资源,但是吃饭的时候就必须使用餐具,而餐桌上的餐具是有限的,原版 ...