第八届河南省赛B.最大岛屿(dfs)
2016-01-01 19:22
330 查看
B.最大岛屿
Time Limit: 1 Sec Memory Limit: 128 MB Submit: 30 Solved: 18 [Submit][Status][Web Board]Description
神秘的海洋,惊险的探险之路,打捞海底宝藏,激烈的海战,海盗劫富等等。加勒比海盗,你知道吧?杰克船长驾驶着自己的的战船黑珍珠1号要征服各个海岛的海盜,最后成为海盗王。 这是一个由海洋、岛屿和海盗组成的危险世界。面对危险重重的海洋与诡谲的对手,如何凭借智慧与运气,建立起一个强大的海盗帝国。杰克船长手头有一张整个海域的海图,上面密密麻麻分布着各个海屿的位置及面积。他想尽快知道整个海域共有多少岛屿以及最大岛屿的面积。
Input
第1行: M N T 表示海域的长,宽及一个单位表示的面积大小接下来有M行 ,每行有N个01组成的序列以及其中穿插一些空格。0表示海水,1表示陆地,其中的空格没用,可以忽略掉。
①若一个陆地八个方向之一(上、下、左、右、左上、右上、左下、右下)的位置也是陆地,则视为同一个岛屿。
② 假设第一行,最后一行,第一列,最后一列全为0.
③ 1<M, N≤500 1<T≤100000
Output
输出一行,有2个整数,一个空格间隔,表示整个海域的岛屿数,以及最大岛屿的面积Sample Input
8 16 99 00000000 00000000 0000110011000000 0001111000111000 0000000 00 0000000 00111 111000001 10 001110000 0000000 0100001111 111100 0000000000000000
Sample Output
5 990
HINT
Source
第八届河南省赛题解:dfs水题,让求岛屿数目,以及最大长度;
代码:
#include<iostream> #include<cstring> #include<cstdio> #include<cmath> #include<algorithm> using namespace std; #define mem(x,y) memset(x,y,sizeof(x)) #define SI(x) scanf("%d",&x) #define SL(x) scanf("%lld",&x) #define PI(x) printf("%d",x) #define PL(x) printf("%lld",x) #define P_ printf(" ") const int INF=0x3f3f3f3f; const double PI=acos(-1.0); int mp[550][550]; char s[10010]; int ans,step; int disx[8]={0,0,1,-1,1,-1,1,-1}; int disy[8]={1,-1,0,0,1,-1,-1,1}; int M,N; void dfs(int x,int y){ step++; ans=max(ans,step); mp[x][y]=0; int nx,ny; for(int i=0;i<8;i++){ nx=x+disx[i];ny=y+disy[i]; if(nx<0||ny<0||nx>=M||ny>=N)continue; if(mp[nx][ny])dfs(nx,ny); } } int main(){ int T; while(~scanf("%d%d%d",&M,&N,&T)){ getchar(); for(int i=0;i<M;i++){ gets(s); int k=0; for(int j=0;s[j];j++) if(isdigit(s[j]))mp[i][k++]=s[j]-'0'; } ans=0; int cnt=0; for(int i=0;i<M;i++) for(int j=0;j<N;j++){ if(mp[i][j]){ cnt++; step=0; dfs(i,j); } } printf("%d %d\n",cnt,ans*T); } return 0; }
相关文章推荐
- 面向对象设计原则---迪米特法则
- 2016新年快乐
- 编码
- git中多人协同开发
- zzuoj--10400--海岛争霸(并查集)
- 2015总结
- char to int
- windows下建立文件的换行符^M导致linux下的shell脚本执行错误的解决方式
- zzuoj--10400--海岛争霸(并查集)
- word2vec使用说明
- python升级
- Git客户端TortoiseGit(Windows系统)的使用方法
- hdu 2838 Cow Sorting(树状数组)
- python升级
- VS中调试DLL工程的正确方法
- Android 网络通信框架Volley完全解析(一)
- 块元素、内联元素、inline-block的特点
- POJ 3589 Number-guessing Game(简单题)
- 猜拳游戏(函数调用)
- SQL数据库的使用:创建表结构