Antenna Placement
Time Limit: 1000MS   Memory Limit: 65536K
Total Submissions: 6438   Accepted: 3176
看了别人的题解才过的。。。 渣啊。。
最基本的是构图

城市才是要构造的二分图的顶点!

构造方法例如以下:

比如输入:

*oo

***

O*o

时,能够抽象为一个数字地图:

100

234

050

数字就是依据输入的城市次序作为该城市的编号,0代表该位置没有城市。

然后依据题目的“范围”规则,从第一个城市開始。以自身作为中心城市,向四个方向的城市进行连线(覆盖)

因此就行得到边集:

e12  e21     e32     e43    e53

e23     e34

e35

能够看到,这些边都是有向边,可是每一条边都有与其相应的一条相反边。

随意两个城市(顶点)之间的边是成对出现的

那么我们就能够确定下来。应该 构造无向二分图(事实上无向=双向)

由于若要构造有向的二分图时,须要推断已出现的边,是非常麻烦的工作

为了把有向图G构造为无向二分图,这里须要引入一个新名词“拆点”

事实上就是把原有向图G的每个顶点都”拆分(我觉得复制更准确)”为2个点,分别属于所要构造的二分图的两个顶点集

比如在刚才的样例中抽出一条有向边e12举例说明:

复制顶点1和顶点2。使得1。2∈V1;  1’。2’∈V2 。不难发现|V1|=|V2|

依据边e12和e21,得到无向二分图:

那么同理就能够得到刚才的样例的 无向二分图为:

再继而通过无向二分图,以V1的元素作为row,V2的元素作为col。构造 可达矩阵 存储到计算机

1’  2’  3’  4’  5’

1  F  T   F   F   F

2  T  F   T   F   F

3  F  T   F   T   T

4  F  F   T   F   F

5  F  F   T   F   F

接下来就是要求这个 无向二分图的最小路径覆盖 了

利用公式:

无向二分图的最小路径覆盖 = 顶点数 – 最大二分匹配数/2

顶点数:就是用于构造无向二分图的城市数。即进行“拆点”操作前的顶点数量

最大二分匹配书之所以要除以2。是由于进行了“拆点”擦奥做做使得匹配总数多了一倍。因此除以2得到原图的真正的匹配数

最后剩下的问题就是求最大二分匹配数了,用匈牙利算法,这就不多说了。參考POJ3041的做法,基本一摸一样。

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. using namespace std;
  5. int map[45][41];
  6. int city[405][405];
  7. int vis[405],link[405];
  8. int sum,v1,v2,ip;
  9. int dx[4]={1,0,-1,0};
  10. int dy[4]={0,-1,0,1};
  11. int xyl(int x)
  12. {
  13. int i;
  14. for(i=1;i<=v2;i++)
  15. if(city[x][i]&&!vis[i])
  16. {
  17. vis[i]=1;
  18. if(!link[i]||xyl(link[i]))
  19. {
  20. link[i]=x;
  21. return 1;
  22. }
  23. }
  24. return 0;
  25. }
  26. void search()
  27. {
  28. int i;
  29. for(i=1;i<=v1;i++)
  30. {
  31. memset(vis,0,sizeof vis);
  32. if(xyl(i))
  33. sum++;
  34. }
  35. return ;
  36. }
  37. int main()
  38. {
  39. int cas,i,j,row,col;
  40. cin>>cas;
  41. while(cas--)
  42. {
  43. memset(map,0,sizeof map);
  44. memset(city,0,sizeof city);
  45. memset(link,0,sizeof link);
  46. ip=0;
  47. sum=0;
  48.  
  49. cin>>row>>col;
  50. char a;
  51. for(i=1;i<=row;i++)
  52. for(j=1;j<=col;j++)
  53. {
  54. cin>>a;
  55. if(a=='*')
  56. map[i][j]=++ip;
  57. }
  58. for(i=1;i<=row;i++)
  59. for(j=1;j<=col;j++)
  60. if(map[i][j])
  61. for(int k=0;k<4;k++)
  62. {
  63. int xx=i+dx[k];
  64. int yy=j+dy[k];
  65. if(map[xx][yy])
  66. city[map[i][j]][map[xx][yy]]=1;
  67. }
  68. v1=v2=ip;
  69. search();
  70. cout<<ip-sum/2<<endl;
  71. }
  72. return 0;
  73. }

poj 3020 Antenna Placement(二分无向图 匈牙利)的更多相关文章

  1. 二分图最大匹配(匈牙利算法) POJ 3020 Antenna Placement

    题目传送门 /* 题意:*的点占据后能顺带占据四个方向的一个*,问最少要占据多少个 匈牙利算法:按坐标奇偶性把*分为两个集合,那么除了匹配的其中一方是顺带占据外,其他都要占据 */ #include ...

  2. poj 3020 Antenna Placement(最小路径覆盖 + 构图)

    http://poj.org/problem?id=3020 Antenna Placement Time Limit: 1000MS   Memory Limit: 65536K Total Sub ...

  3. POJ 3020 Antenna Placement 【最小边覆盖】

    传送门:http://poj.org/problem?id=3020 Antenna Placement Time Limit: 1000MS   Memory Limit: 65536K Total ...

  4. POJ 3020 Antenna Placement【二分匹配——最小路径覆盖】

    链接: http://poj.org/problem?id=3020 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=22010#probl ...

  5. POJ 3020——Antenna Placement——————【 最小路径覆盖、奇偶性建图】

    Antenna Placement Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u S ...

  6. poj 3020 Antenna Placement (最小路径覆盖)

    链接:poj 3020 题意:一个矩形中,有n个城市'*'.'o'表示空地,如今这n个城市都要覆盖无线,若放置一个基站, 那么它至多能够覆盖本身和相邻的一个城市,求至少放置多少个基站才干使得全部的城市 ...

  7. POJ 3020 Antenna Placement 最大匹配

    Antenna Placement Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6445   Accepted: 3182 ...

  8. POJ 3020 Antenna Placement

    Antenna Placement Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 5645 Accepted: 2825 Des ...

  9. POJ 3020 Antenna Placement(二分图 匈牙利算法)

    题目网址:  http://poj.org/problem?id=3020 题意: 用椭圆形去覆盖给出所有环(即图上的小圆点),有两种类型的椭圆形,左右朝向和上下朝向的,一个椭圆形最多可以覆盖相邻的两 ...

随机推荐

  1. Java获取一个文件夹内的所有文件(包括所有子文件夹内的)

    输入文件数组.文件夹路径 返回的文件在输入的文件数组中 private void getFiles(ArrayList<File> fileList, String path) { Fil ...

  2. 浏览器的两种模式quirks mode 和strict mode

    关键字: javascript.quirks mode.strict mode 在看js代码时,有时会看到关于quirks mode(怪异模式)和strict mode(严格格式)的东西,一直也没深究 ...

  3. SpringBoot项目的mybatis逆向工程

    <dependencies> <!--mybatis--> <dependency> <groupId>org.mybatis.spring.boot& ...

  4. axios方法get及post代码示例

    show: function(){ //get方式 //赋值给变量self var self = this; var url = "hotcity.json"; axios.get ...

  5. 04Servlet的生命周期

    Servlet的生命周期 Servlet运行在Servlet容器中,其生命周期由容器来管理.Servlet的生命周期通过javax.servlet.Servlet接口中的init().service( ...

  6. Java编辑编译及运行环境

    Java编辑编译及运行环境 Microsoft Windows 编辑工具 EditPlus JDK JDK(Java Development Kit,Java开发工具包)安装JDK之后,其中bin文件 ...

  7. 12Oracle Database SQL程序

    Oracle Databse SQL 程序 程序块 在这之前,我们所有的sql语句都是一句一句执行的,如果我们把很多事情看作一个整体提交执行的话,必须使用程序块. 声明部分:声名变量及初始化 关键字: ...

  8. C++ map使用总结

    0. Backgroud 此文章源于博主(sunshinewave),转到自己博客以后方便查看 map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次, ...

  9. React-native SyntaxError: Unexpected token ...

    更新 node.js 版本到  v6.11.1. https://github.com/facebook/react-native/issues/15040

  10. 洛谷——P1404 平均数

    P1404 平均数 题目描述 给一个长度为n的数列,我们需要找出该数列的一个子串,使得子串平均数最大化,并且子串长度>=m. 前缀和+二分答案 #include<iostream> ...