POJ2816红与黑
2015-07-23 17:30
141 查看
Description
有一间长方形的房子,地上铺了红色、黑色两种颜色的正方形瓷砖。你站在其中一块黑色的瓷砖上,只能向相邻的黑色瓷砖移动。请写一个程序,计算你总共能够到达多少块黑色的瓷砖。
Input
包括多个数据集合。每个数据集合的第一行是两个整数W和H,分别表示x方向和y方向瓷砖的数量。W和H都不超过20。在接下来的H行中,每行包括W个字符。每个字符表示一块瓷砖的颜色,规则如下
1)‘.’:黑色的瓷砖;
2)‘#’:白色的瓷砖;
3)‘@’:黑色的瓷砖,并且你站在这块瓷砖上。该字符在每个数据集合中唯一出现一次。
当在一行中读入的是两个零时,表示输入结束。
Output
对每个数据集合,分别输出一行,显示你从初始位置出发能到达的瓷砖数(记数时包括初始位置的瓷砖)。
Sample Input
6 9
....#.
.....#
......
......
......
......
......
#@...#
.#..#.
0 0
Sample Output
45
代码:
有一间长方形的房子,地上铺了红色、黑色两种颜色的正方形瓷砖。你站在其中一块黑色的瓷砖上,只能向相邻的黑色瓷砖移动。请写一个程序,计算你总共能够到达多少块黑色的瓷砖。
Input
包括多个数据集合。每个数据集合的第一行是两个整数W和H,分别表示x方向和y方向瓷砖的数量。W和H都不超过20。在接下来的H行中,每行包括W个字符。每个字符表示一块瓷砖的颜色,规则如下
1)‘.’:黑色的瓷砖;
2)‘#’:白色的瓷砖;
3)‘@’:黑色的瓷砖,并且你站在这块瓷砖上。该字符在每个数据集合中唯一出现一次。
当在一行中读入的是两个零时,表示输入结束。
Output
对每个数据集合,分别输出一行,显示你从初始位置出发能到达的瓷砖数(记数时包括初始位置的瓷砖)。
Sample Input
6 9
....#.
.....#
......
......
......
......
......
#@...#
.#..#.
0 0
Sample Output
45
代码:
#include<stdio.h> #include<stdlib.h> char puzzle[21][21]; int w,h; int f(int x,int y){ if(x<0||x>=h||y<0||y>=w)return 0; if(puzzle[x][y]=='#')return 0; else {puzzle[x][y]='#'; return 1+f(x-1,y)+f(x+1,y)+f(x,y-1)+f(x,y+1);}} int main(){ while(1){ scanf("%d %d",&w,&h); if(w==0&&h==0)break; getchar(); int i,j; for(i=0;i<h;i++) { gets(puzzle[i]);} for(i=0;i<h;i++) for(j=0;j<w;j++) if(puzzle[i][j]=='@') printf("%d\n",f(i,j));} return 0;}
相关文章推荐
- 产品运营学习笔记(1)
- Spring MVC项目启动报错信息__待解决
- 下拉刷新与上拉加载
- linux netstat 命令简解
- 一个人的旅行(floyd+dijskra+SPFA+Bellman)
- 获得UIView对应 的viewController
- win7取消共享设置
- MySQL Sending data导致查询很慢的问题详细分析
- 透视矩阵的推导(最直观、最深入、最还原,看完请点赞。)
- Spring task quartz 定时任务的几种实现
- 各种排序算法的实现,总结与比较
- Dialog自定义布局
- unity3d打包和包的使用
- mac 免密码登陆服务器
- NSString什么时候用copy,什么时候用strong
- 分布式锁实现
- 学习文章连载一
- 树莓派实现用pi用户自动登录
- windows下nginx安装、配置与使用
- Android的API版本和名称对应关系