codevs1002搭桥(建图+Prim)
/*
先来个灌水法 然后建图跑最小生成树
注意观察题目中的规则 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)的更多相关文章
- codevs1002搭桥(prim)
题目描述: 这是道题题意有点迷(或者是我语文不好),但其实实际上求的就是图中连通块的个数,然后在连通块与连通块之间连边建图跑最小生成树.但是--这个图可能是不连通的--求桥的数量和总长 于是我立刻想到 ...
- codevs1002 搭桥
题目描述 Description 有一矩形区域的城市中建筑了若干建筑物,如果某两个单元格有一个点相联系,则它们属于同一座建筑物.现在想在这些建筑物之间搭建一些桥梁,其中桥梁只能沿着矩形的方格的边沿搭建 ...
- 【BZOJ-1570】BlueMary的旅行 分层建图 + 最大流
1570: [JSOI2008]Blue Mary的旅行 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 388 Solved: 212[Submit ...
- 【BZOJ-4289】Tax 最短路 + 技巧建图
4289: PA2012 Tax Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 168 Solved: 69[Submit][Status][Dis ...
- CF467D Fedor and Essay 建图DFS
Codeforces Round #267 (Div. 2) CF#267D D - Fedor and Essay D. Fedor and Essay time limit per test ...
- UVa 3487 & 蜜汁建图
题意: 有两家公司都想向政府申请某些资源的使用权,并且他们都提供了一些申请列表,列表中含有申请费用和资源种类,同一家公司的申请列表之间不含有重复的资源.政府只可以完整地接受和拒绝谋一份申请列表,问政府 ...
- POJ 2226 最小点覆盖(经典建图)
Muddy Fields Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8881 Accepted: 3300 Desc ...
- HDU 5669 线段树优化建图+分层图最短路
用线段树维护建图,即把用线段树把每个区间都标号了,Tree1中子节点有到达父节点的单向边,Tree2中父节点有到达子节点的单向边. 每次将源插入Tree1,汇插入Tree2,中间用临时节点相连.那么T ...
- 【BZOJ-2879】美食节 最小费用最大流 + 动态建图
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1366 Solved: 737[Submit][Status] ...
随机推荐
- UFLDL实验报告1: Softmax Regression
PS:这些是今年4月份,跟斯坦福UFLDL教程时的实验报告,当时就应该好好整理的…留到现在好凌乱了 Softmax Regression实验报告 1.Softmax Regression实验描述 So ...
- 如何使用ASP.NET Web API OData在Oracle中使用Entity Framework 6.x Code-First方式开发 OData V4 Service
环境: Visual Studio 2013 + .Net Framework 4.5.2 1.新建项目 2.安装OData,ODP.NET 安装的包: 下面是部分代码: using System; ...
- uitextfield动态限制输入的字数-b
1.定义一个事件: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 ...
- Unity OF 3DMax毛坯房制作标准
Unity OF 3DMax毛坯房制作标准 1.模型 2.贴图 3.模型塌陷展UV 4.灯光 5.Radiosity 6.Render To Texture 7.烘焙 8.导出 1.模型回目录 ...
- (转载)php curl_init函数用法
(转载)http://blog.sina.com.cn/s/blog_640738130100tsig.html 使用PHP的cURL库可以简单和有效地去抓网页.你只需要运行一个脚本,然后分析一下你所 ...
- 数据结构(线段树):CodeForces 145E Lucky Queries
E. Lucky Queries time limit per test 3 seconds memory limit per test 256 megabytes input standard in ...
- 线性代数(矩阵乘法):POJ 3233 Matrix Power Series
Matrix Power Series Description Given a n × n matrix A and a positive integer k, find the sum S = ...
- vim下缩进及高亮设置
1.配置文件的位置 在目录 /etc/ 下面,有个名为vimrc的文件,这是系统中公共的vim配置文件,对所有用户都有效.而在每个用户的主目录下,都可以自己建立私有的配置文件,命名为:“.vimrc” ...
- UNIX环境下的消息队列
消息队列和共享内存一样,也是一种IPC对象.消息队列其实就是消息的链表,每一则消息都是用户自己的结构体.服务端这边创建消息队列,客户端这边打开消息队列,两个进程就可以进行通信.创建和打开消息队列使用函 ...
- NOI题库1159 Maze
1159:Maze 总时间限制: 2000ms 内存限制: 65536kB 描述 Acm, a treasure-explorer, is exploring again. This time he ...