UNIX的插头问题
UNIX的插头问题
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目描述
因为会议室被审计为招待来自世界各地的记者的场所,它装备了一些电气插座以匹配各个国家使用的电器的不同插头形状和电压。当然,这些插座的规格是以这个会议室建成时世界各国的规格作为标准的。不幸的是,由于这座会议室年代久远,它建成时,记者还只是使用很少量的电子和电气设备,所以它对每种类型只配备了一个插座。今天,记者像其他人一样,需要很多设备才能工作:掌上型计算器,手提电话,录音机,寻呼机,电咖啡壶,微波炉,电吹风,电熨斗,电动牙刷,等等。自然,这些设备当中有许多可以靠电池驱动的,但是看起来这个会议将会冗长乏味,所以还是希望这些设备尽可能从插座供电。
在会议开始前,你将记者所有可能使用的设备集中起来,尝试将它们接到插座上。你注意到有些设备的插头没有相应的插座。你怀疑这些设备来自一些在这座会议室建成时还不存在的国家。对某些插座,也许有许多设备都是用对应的插头;而对另一些插座,也许没有任何设备使用对应的插头。 为了解决这个问题,你走到附近一家五金店气商店。这家商店出售一些转接头,可以将一种插头转换成另一种插头。一个转接头还可以接到另一个转接头上。并非所有插座和插头的组合都有相应的转接头,但是对每种出售的转接头,商店都有足够的存货。
输入
输出
示例输入
4
A
B
C
D
5
laptop B
phone C
pager B
clock B
comb X
3
B X
X A
X D
示例输出
1
分析:二分最大匹配;n个插座作为一列,m个插头作为一列,形成二部图,接下来就是把可以对应的插座直接和插头连接或者间接和插头连接起来,对于每个插头或插座的名称离散化,然后对k个转换器建立单项边,然后搜索,可以搜到的点就可以间接连边;
程序:
#include"stdio.h"
#include"string.h"
#include"queue"
#include"stack"
#include"algorithm"
#include"vector"
#include"iostream"
#include"math.h"
#include"map"
#include"stdlib.h"
#define M 222
#define inf 100000000
using namespace std;
int G[M][M],y[M],use[M],vis[M];
struct node
{
int v;
node(int vv)
{
v=vv;
}
};
vector<node>edge[M];
int finde(int x,int m)
{
for(int i=1;i<=m;i++)
{
if(!use[i]&&G[x][i])
{
use[i]=1;
if(!y[i]||finde(y[i],m))
{
y[i]=x;
return 1;
}
}
}
return 0;
}
int slove(int n,int m)
{
memset(y,0,sizeof(y));
int ans=0;
for(int i=1;i<=n;i++)
{
memset(use,0,sizeof(use));
ans+=finde(i,m);
}
return ans;
}
void dfs(int u)
{
vis[u]=1;
for(int i=0;i<(int)edge[u].size();i++)
{
int v=edge[u][i].v;
if(!vis[v])
dfs(v);
}
}
int main()
{
int n,m,i,j,k;
char ch[M][33],str[33],ch1[M][33],str1[33],str2[33];
while(scanf("%d",&n)!=-1)
{
map<string,int>mp;
int num=0;
for(i=1;i<=n;i++)
{
scanf("%s",ch[i]);
if(!mp[ch[i]])
mp[ch[i]]=++num;
}
scanf("%d",&m);
for(i=1;i<=m;i++)
{
scanf("%s%s",str,ch1[i]);
if(!mp[ch1[i]])
mp[ch1[i]]=++num;
}
scanf("%d",&k);
for(i=1;i<=k;i++)
{
scanf("%s%s",str1,str2);
edge[mp[str2]].push_back(node(mp[str1]));
}
memset(G,0,sizeof(G));
for(i=1;i<=n;i++)
{
int u=mp[ch[i]];
memset(vis,0,sizeof(vis));
dfs(u);
for(j=1;j<=m;j++)
{
int v=mp[ch1[j]];
if(vis[v])
G[i][j]=1;
}
}
int ans=slove(n,m);
printf("%d\n",m-ans);
/*for(i=1;i<=n;i++)
{
for(j=1;j<=m;j++)
printf("%d-->%d:%d\n",i,j,G[i][j]);
}*/
for(i=1;i<=num;i++)
edge[i].clear();
}
return 0;
}
UNIX的插头问题的更多相关文章
- UVA 753 UNIX 插头(EK网络流+Floyd传递闭包)
UNIX 插头 紫书P374 [题目链接]UNIX 插头 [题目类型]EK网络流+Floyd传递闭包 &题解: 看了书之后有那么一点懂了,但当看了刘汝佳代码后就完全明白了,感觉他代码写的好牛逼 ...
- ACM/ICPC 之 Unix会议室(POJ1087)
采用EK算法解网络流经典题,本题构图思路比较明确. //Unix会议室插座转换 //网络流-EK算法 //Time:47Ms Memory:1188K #include<iostream> ...
- POJ1087 A Plug for UNIX(网络流)
A Plug for UNIX Time Limit: 1000MS Memory Limit: 65536K Total S ...
- 【poj1087/uva753】A Plug for UNIX(最大流)
A Plug for UNIX Description You are in charge of setting up the press room for the inaugural meeti ...
- UVa753/POJ1087_A Plug for UNIX(网络流最大流)(小白书图论专题)
解题报告 题意: n个插头m个设备k种转换器.求有多少设备无法插入. 思路: 定义源点和汇点,源点和设备相连,容量为1. 汇点和插头相连,容量也为1. 插头和设备相连,容量也为1. 可转换插头相连,容 ...
- TZOJ 1911 A Plug for UNIX(最大流)
描述 You are in charge of setting up the press room for the inaugural meeting of the United Nations In ...
- POJ1087 A Plug for UNIX 2017-02-12 13:38 40人阅读 评论(0) 收藏
A Plug for UNIX Description You are in charge of setting up the press room for the inaugural meeting ...
- POJ1087:A Plug for UNIX(最大流)
A Plug for UNIX 题目链接:https://vjudge.net/problem/POJ-1087 Description: You are in charge of setting u ...
- uva753 A Plug for UNIX 网络流最大流
C - A Plug for UNIX You are in charge of setting up the press room for the inaugural meeting of t ...
随机推荐
- 下面属于javascript对象的有:( )
下面属于javascript对象的有:( ) A. Window B. Document C. Form D. String E. Navigator 解答:ACE
- R语言绘图布局
在R语言中,par 函数可以设置图形边距,其中oma 参数设置outer margin, mar 参数设置margin, 这些边距有什么不同呢,通过box函数可以直观的看到 box 默认在当前图形绘制 ...
- redis的学习使用(ubuntu系统下)
1.安装redis,/usr/local/redis-4.0.1/src/redis-server启动服务,若想启动后自动退出redis控制台进行其他操作,可配置redis.config中 daem ...
- 让UIButton在按下时没有高亮效果
How are you setting the images for the different UIControlStates on the button? Are you setting a ba ...
- 搜集的一些酷炫的金属色 ,RGB值 和大家分享一下
开发iOS程序过程中会使用到RGB,要注意每个RGB值都要除以 255.0 ,注意: ' .0 ' 不能省!! 一下是本人搜集的一些酷炫金属色的RGB值: 黄金 242,192,86 石墨 87, ...
- LoadRunner 调用dll方法
本文主要介绍简单DLL的编写方法及在LoadRunner中局部调用与全局调用DLL方法. 1.动态链接库的编写 在Visual C++6.0开发环境下,打开FileNewProject选项,可以选择W ...
- MathType中输入破折号的教程
MathType公式编辑器中的包含的各种数学符号与模板已经足够我们在编辑公式时使用了,但是除此之外,MathType还有一些符号并不是数学专有的符号,但是在数学中也偶尔会用到,比如破折号.MathTy ...
- OpenCV学习:Windows+VS2010+OpenCV配置
OpenCV下载: 百度云下载:https://pan.baidu.com/s/1mhAExdu (2.4.9版本) 下载完成后,双击运行exe,选择输出目录,我选择的是C:\OpenCV 配置环境变 ...
- 【观点】“马云:金融是要为外行人服务",这个观点其实并不新鲜
不久前,马云在外滩国际金融峰会演讲,称金融行业需要“搅局者”.他说:“今天的金融,确实做得不错,没有今天这样的金融机构,中国的经济30年来不可能发展到今天,但是靠今天银行的机制,我不相信能支撑30年以 ...
- boa.config
# boa -c /usr/local/boa Port 80 #User 0#Group 0 ErrorLog /dev/console AccessLog /dev/console ServerN ...