第八届河南省程序设计大赛-B.最大岛屿0000110011000000
最大岛屿
- 描述
 - 
神秘的海洋,惊险的探险之路,打捞海底宝藏,激烈的海战,海盗劫富等等。加勒比海盗,你知道吧?杰克船长驾驶着自己的的战船黑珍珠1号要征服各个海岛的海盜,最后成为海盗王。 这是一个由海洋、岛屿和海盗组成的危险世界。面对危险重重的海洋与诡谲的对手,如何凭借智慧与运气,建立起一个强大的海盗帝国。
杰克船长手头有一张整个海域的海图,上面密密麻麻分布着各个海屿的位置及面积。他想尽快知道整个海域共有多少岛屿以及最大岛屿的面积。
- 输入
 - 第1行:M N T,表示海域的长,宽及一个单位表示的面积大小
接下来有M行 ,每行有N个01组成的序列以及其中穿插一些空格。0表示海水,1表示陆地,其中的空格没用,可以忽略掉。
 - 输出
 - 输出一行,有2个整数,一个空格间隔,表示整个海域的岛屿数,以及最大岛屿的面积
 - 
最大岛屿
时间限制:1000 ms | 内存限制:65535 KB- 描述
 - 
神秘的海洋,惊险的探险之路,打捞海底宝藏,激烈的海战,海盗劫富等等。加勒比海盗,你知道吧?杰克船长驾驶着自己的的战船黑珍珠1号要征服各个海岛的海盜,最后成为海盗王。 这是一个由海洋、岛屿和海盗组成的危险世界。面对危险重重的海洋与诡谲的对手,如何凭借智慧与运气,建立起一个强大的海盗帝国。
杰克船长手头有一张整个海域的海图,上面密密麻麻分布着各个海屿的位置及面积。他想尽快知道整个海域共有多少岛屿以及最大岛屿的面积。
- 输入
 - 第1行:M N T,表示海域的长,宽及一个单位表示的面积大小
接下来有M行 ,每行有N个01组成的序列以及其中穿插一些空格。0表示海水,1表示陆地,其中的空格没用,可以忽略掉。
 - 输出
 - 输出一行,有2个整数,一个空格间隔,表示整个海域的岛屿数,以及最大岛屿的面积
 - 样例输入
 - 
8 16 99
 - 
00000000 00000000
 - 
0001111000111000
0000000 00 0000000
00111 111000001 10
001110000 0000000
0100001111 111100
0000000000000000
 - 样例输出
 - 
5 990
 - 提示
 - ①若一个陆地八个方向之一(上、下、左、右、左上、右上、左下、右下)的位置也是陆地,则视为同一个岛屿。
② 假设第一行,最后一行,第一列,最后一列全为0.
③ 1<M, N≤500 1<T≤100000 - 来源
 - 第八届河南省程序设计大赛
 
 
 
 
这个题就是把南阳oj(NYOJ)上水池数目和福州oj(FZU)结合了一下,思路都一样,简单搜索,就是要细心一点;
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
const int N=500+10;
char a[N][N<<1];
int sum1;
long long sum2,sum3;
int dx[8]= {0,0,-1,-1,-1,1,1,1};
int dy[8]= {1,-1,0,-1,1,0,-1,1};
void dfs(int x,int y)
{
a[x][y]='0';//搜索过就标为0,然后继续往八个方向继续搜索;
sum2=max(sum2,sum3);//把最大面积求出来;
for(int i=0; i<8; i++)
{
int xx=x+dx[i],yy=y+dy[i];//八个方向;
if(a[xx][yy]=='1')//只要为一就继续搜索,然后面积加一;
{
sum3++;
dfs(xx,yy);
}
}
}
void xiao(char* a,int x)//消去空格;
{
for(int i=0; i<x; i++)
if(a[i]==' ')
{
for(int j=i; j<x; j++)
a[j]=a[j+1];//整体前移;
x--;
i--;可能会有连续几个空格,所以还要判断当前被覆盖的位置是不是空格;
}
}
int main()
{
int n,m,t;
int i,j;
memset(a,0,sizeof(a));
scanf("%d%d%d",&n,&m,&t);
getchar();
for(i=0; i<n; i++)
{ gets(a[i]);
int x=strlen(a[i]);
if(x!=m)
xiao(a[i],x);
}
sum1=sum2=sum3=0;
for(i=0; i<n; i++)
for(j=0; j<m; j++)
{
if(a[i][j]=='1')
{
sum1++;//搜索过就变为0了,所以可求出有几块不相邻的岛屿;
sum3=1;
dfs(i,j);
}
}
sum2*=t;
printf("%d %I64d\n",sum1,sum2);
}
第八届河南省程序设计大赛-B.最大岛屿0000110011000000的更多相关文章
- NYOJ--1236--挑战密室(第八届河南省程序设计大赛)
		
挑战密室 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 R组织的特工Dr. Kong 为了寻找丢失的超体元素,不幸陷入WTO密室.Dr. Kong必须尽快找到解锁密 ...
 - Distribution(F题)---第八届河南省程序设计大赛
		
Description One day , Wang and Dong in the Dubai desert expedition, discovered an ancient castle. Fo ...
 - nyoj1237 最大岛屿(河南省第八届acm程序设计大赛)
		
题目1237 pid=1237" style="color:rgb(55,119,188)">题目信息 执行结果 本题排行 讨论区 最大岛屿 时间限制:1000 m ...
 - nyoj 1239 引水project (河南省第八届acm程序设计大赛)
		
题目1239 pid=1239" style="color:rgb(55,119,188)">题目信息 pid=1239" style="col ...
 - nyoj 1238 最少换乘 (河南省第八届acm程序设计大赛)
		
题目1238 题目信息 执行结果 本题排行 pid=1238" style="text-decoration:none; color:rgb(55,119,188)"&g ...
 - NYOJ-712 探寻宝藏(第六届河南省程序设计大赛)
		
探 寻 宝 藏 时间限制:1000 ms | 内存限制:65535 KB 难度:5 描述 传说HMH大沙漠中有一个M*N迷宫,里面藏有许多宝物.某天,Dr.Kong找到了迷宫的地图,他发现迷宫 ...
 - nyoj170 网络的可靠性(第三届河南省程序设计大赛)
		
题目170 题目信息 执行结果 pid=170" style="text-decoration:none; color:rgb(55,119,188)">本题排行 ...
 - 河南省第八届ACM程序设计大赛
		
A:挑战密室 #include <iostream> #include <cstdio> #include <cstring> #include <algor ...
 - 河南省第八届ACM程序设计大赛总结
		
简单的对这次省赛做个总结:总体来说这个比赛过程中做的还算比较顺利,虽然中间多多少少遇到一些坑,正式比赛开始后,我们就开始找水题,当然了我首先把英文题目翻译了一遍,发现了一道水题,这道题目其实就是判断点 ...
 
随机推荐
- JDBC——入门知识【转】
			
1. 什么是JDBC:Java数据库连接性(JavaDatabase Connectivity) API,允许用户从Java应用程序中访问任何表格化数据源. 2. JDBC除了提供到更宽范围的SQ ...
 - qconbeijing2014
			
http://2014.qconbeijing.com/videoslides.html 周一 周二 周三 周四 周五 周六 2014年5月19日 Deep Dive into Amazon's ...
 - 【学习笔记】一:JavaScript简介
			
1.JavaScript简史 1)JavaScript最初的功能只是用来在客户端做简单的输入验证器,减少客户端与服务器端的数据交互(毕竟那个年代网速有限). 2)JavaScript的飞速发展及Net ...
 - Windows 2016 安装Sharepoint 2016 预装组件失败
			
Windows 2016 安装Sharepoint 2016 预装组件失败 日志如下: -- :: - Request for install time of Web 服务器(IIS)角色 -- :: ...
 - BottomNavigationBar底部导航条用法
			
先来张效果图 接下来是实现过程 1.加入依赖 compile 'com.ashokvarma.android:bottom-navigation-bar:1.3.0' 2.xml布局 fragment ...
 - UART协议
			
通用异步收发传输器(Universal Asynchronous Receiver/Transmitter,通常称作UART,读音/ˈjuːart/)是一种异步收发传输器,是电脑硬件的一部分,将资料由 ...
 - 千万千万不要运行的 Linux 命令
			
文中列出的命令绝对不可以运行,即使你觉得很好奇也不行,除非你是在虚拟机上运行(出现问题你可以还原),因为它们会实实在在的破坏你的系统.所以不在root等高级管理权限下执行命令是很好的习惯. 早晚有一天 ...
 - AS400服务程序总结
			
1.服务程序的创建和调用过程 1.1生成module 1.2编写BND文件确定输出接口 1.3生成服务程序 1.3.运行调用程序时,将服务程序导入到作业内存区active group,常驻内存 2.结 ...
 - No-8.其他命令
			
其他命令 目标 查找文件 find 软链接 ln 打包和压缩 tar 软件安装 apt-get 01. 查找文件 find 命令功能非常强大,通常用来在 特定的目录下 搜索 符合条件的文件 序号 命令 ...
 - Maven实战读书笔记(二):Maven坐标与仓库
			
2.1 Maven坐标 Maven坐标是Maven用来表示一个组件依赖的标示. Maven通过下面几个元素定义坐标:groupId.artifactId.version.packaging.class ...