/*
先来个灌水法 然后建图跑最小生成树
注意观察题目中的规则 a[1][i]!=a[1][j]&&abs(a[2][i]-a[2][j])<=1
建图的时候可以每一个建筑物都看成一个点 然后计算需要几个桥
同一个城市的不用桥
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
using namespace std;
int n,m,tot,g[][],a[][],minn[],f[],sum,bb;
char s[][];
int xx[]={,,,,,,-,-,-};//枚举8个方向
int yy[]={,,-,-,,,-,,};
void Dfs(int x,int y)
{
s[x][y]=tot+;
int i,j,ox,oy;
for(i=;i<=;i++)//枚举8个方向
{
ox=x+xx[i];oy=y+yy[i];
if(ox>&&ox<=n&&oy>&&oy<=m&&s[ox][oy]=='#')
Dfs(ox,oy);
}
}
int main()
{
cin>>n>>m;
int i,j,k,l;
for(i=;i<=n;i++)
for(j=;j<=m;j++)
cin>>s[i][j];
for(i=;i<=n;i++)
for(j=;j<=m;j++)
if(s[i][j]=='#')//统计城市个数
{
tot++;
Dfs(i,j);
}
cout<<tot<<endl;
memset(g,,sizeof(g));
tot=;//建筑物数量
for(i=;i<=n;i++)
{
for(j=;j<=m;j++)
if(s[i][j]!='.')//记录每个建筑物的信息
{
tot++;
a[][tot]=i;//横坐标
a[][tot]=j;//纵坐标
}
}
for(i=;i<=tot;i++)//建图(每个点都建 属于一个城市的不同桥)
for(j=i+;j<=tot;j++)
{
if(a[][i]!=a[][j]&&abs(a[][i]-a[][j])<=)//如果符合连桥的条件
{
g[i][j]=abs(a[][i]-a[][j])-;
g[j][i]=g[i][j];
}
else if(a[][i]!=a[][j]&&abs(a[][i]-a[][j])<=)
{
g[i][j]=abs(a[][i]-a[][j])-;
g[j][i]=g[i][j];
}
}
memset(minn,,sizeof(minn));
minn[]=;
for(i=;i<=tot;i++)//跑 Prim
{
k=;
for(j=;j<=tot;j++)
if(f[j]==&&minn[j]<minn[k])
k=j;
f[k]=;
for(j=;j<=tot;j++)
if(f[j]==&&minn[j]>g[k][j])
minn[j]=g[k][j];
}
for(i=;i<=tot;i++)
{
if(minn[i]!=&&minn[i]<)
{
bb++;//统计桥的个数
sum=sum+minn[i];//累加桥的长度
}
}
cout<<endl<<bb<<" "<<sum;
return ;
}

codevs1002搭桥(建图+Prim)的更多相关文章

  1. codevs1002搭桥(prim)

    题目描述: 这是道题题意有点迷(或者是我语文不好),但其实实际上求的就是图中连通块的个数,然后在连通块与连通块之间连边建图跑最小生成树.但是--这个图可能是不连通的--求桥的数量和总长 于是我立刻想到 ...

  2. codevs1002 搭桥

    题目描述 Description 有一矩形区域的城市中建筑了若干建筑物,如果某两个单元格有一个点相联系,则它们属于同一座建筑物.现在想在这些建筑物之间搭建一些桥梁,其中桥梁只能沿着矩形的方格的边沿搭建 ...

  3. 【BZOJ-1570】BlueMary的旅行 分层建图 + 最大流

    1570: [JSOI2008]Blue Mary的旅行 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 388  Solved: 212[Submit ...

  4. 【BZOJ-4289】Tax 最短路 + 技巧建图

    4289: PA2012 Tax Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 168  Solved: 69[Submit][Status][Dis ...

  5. CF467D Fedor and Essay 建图DFS

      Codeforces Round #267 (Div. 2) CF#267D D - Fedor and Essay D. Fedor and Essay time limit per test ...

  6. UVa 3487 & 蜜汁建图

    题意: 有两家公司都想向政府申请某些资源的使用权,并且他们都提供了一些申请列表,列表中含有申请费用和资源种类,同一家公司的申请列表之间不含有重复的资源.政府只可以完整地接受和拒绝谋一份申请列表,问政府 ...

  7. POJ 2226 最小点覆盖(经典建图)

    Muddy Fields Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8881   Accepted: 3300 Desc ...

  8. HDU 5669 线段树优化建图+分层图最短路

    用线段树维护建图,即把用线段树把每个区间都标号了,Tree1中子节点有到达父节点的单向边,Tree2中父节点有到达子节点的单向边. 每次将源插入Tree1,汇插入Tree2,中间用临时节点相连.那么T ...

  9. 【BZOJ-2879】美食节 最小费用最大流 + 动态建图

    2879: [Noi2012]美食节 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1366  Solved: 737[Submit][Status] ...

随机推荐

  1. python【第九篇】多线程、多进程

    内容提要 paramiko模块 进程.与线程区别 python GIL全局解释器锁 多线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生 ...

  2. 轻松解决Win8.1连接受限或无法连接WiFi问题

    在无线网络连接设置窗口中,找到当前连接的无线网络“WLAN状态”,右击查看“状态”. 在“WLAN状态”窗口中找到“无线属性”. 进入“无线网络属性”窗口,切换到“安全”页面,点击“高级设置”.最重要 ...

  3. hadoop 生态系统版本对应问题

    http://hbase.apache.org/book.html 这是hortonworks的哦哦哦哦哦哦哦哦哦哦哦哦 Hadoop 2.x is better than Hadoop 1.x Ha ...

  4. Node.js工具模块

    在Node.js的模块库中提供实用的模块数量. 这些模块都是很常见的,并同时开发基于任何节点的应用程序频繁使用. S.N. 模块的名称和说明 1 OS Module提供基本的操作系统相关的实用功能 2 ...

  5. Maximum Submatrix 2

    Codeforces Round #221 (Div. 1) B:http://codeforces.com/problemset/problem/375/B 题意:给你一个n*m的0,1矩阵,你可以 ...

  6. Tribles(概率)

    Description   Problem ATribblesInput: Standard Input Output: Standard Output GRAVITATION, n."Th ...

  7. border粗细不一

    devicePixelRatio = 1.5 引发的问题

  8. Linux企业级开发技术(7)——libevent企业级开发之锁和线程

    编写多线程程序的时候,在多个线程中同时访问同样的数据并不总是安全的. libevent的结构体在多线程下通常有三种工作方式: 1.某些结构体内在地是单线程的:同时在多个线程中使用它们总是不安全的. 2 ...

  9. 动态规划:NOI2013 快餐店

    Description 小 T打算在城市C开设一家外送快餐店.送餐到某一个地点的时间与外卖店到该地点之间最短路径长度是成正比的,小T希望快餐店的地址选在离最远的顾客距离最近 的地方. 快餐店的顾客分布 ...

  10. 从大学开始学C++到现在的一些感悟

    Since I choose this road, I will not regret it.     --Mereyct 端午过后的第二天,闲着没事,更新一下博客. 写这个博客的原因是,看到了群里有 ...