红与黑
题目描述
有一间长方形的房子,地上铺了红色、黑色两种颜色的正方形瓷砖。你站在其中一块黑色的瓷砖上,只能向相邻的黑 色瓷砖移动。请写一个程序,计算你总共能够到达多少块黑色的瓷砖。
输入
包括多组数据。每组数据的第一行是两个整数W和H,分别表示x方向和y方 向瓷砖的数量。W和H都不超过20。在接下来的H行中,每行包括W个字符。 每个字符表示一块瓷砖的颜色,规则如下: 1)‘.’:黑色的瓷砖;
2)‘#’:红色的瓷砖;
3)‘@’:黑色的瓷砖,并且你站在这块瓷砖上。该字符在每组数据中唯一 出现一次。
当在一行中读入的是两个零时,表示输入结束。 输出 对每组数据,分别输出一行,显示你从初始位置出发能到达的瓷砖数(记数 时包括初始位置的瓷砖)。
【输入样例】
6 9
. . . . # .
. . . . . #
. . . . . .
. . . . . .
. . . . . .
. . . . . .
. . . . . .
# @ . . . #
. # . . # .
0 0
【输出样例】
45
#include <iostream>
#include <iomanip>
using namespace std;
char a[110][110];
int b[30][30];
int n,m;
int cnt = 1;
int di[] = {0,1,0,-1};
int dj[] = {1,0,-1,0};
void aaa(int,int);
int main()
{
while(true)
{
cin>>m>>n;
if(m==0&&n==0)
{
break;
}
int ii,jj;
for(int i = 0;i<n;i++)
{
for(int j = 0;j<m;j++)
{
cin>>a[i][j];
if(a[i][j]=='@')
{
ii = i;
jj = j;
}
}
}
aaa(ii,jj);
cout<<cnt<<endl;
}
return 0;
}
void aaa(int i,int j)
{
a[i][j] = '#';
b[i][j] = cnt;
for(int qqq = 0;qqq<4;qqq++)
{
int ti = i+di[qqq];
int tj = j+dj[qqq];
if(ti>=0&&ti<n&&tj>=0&&tj<m&&a[ti][tj]!='#')
{
cnt++;
aaa(ti,tj);
}
}
return;
}
泳池
题目描述
小C在一个排水系统不太好的学校上学。又是一个下雨天,学校里高低不平积了很多水。小C突发奇想:如果大雨一直 下,多久以后我可以在学校里游泳呢? 学校是 N x N 的坐标方格 grid 中,每一个方格的值 grid(i,j)表示在位置 (i,j) 的高度。现在开始下雨了。当时间为 t 时, 此时雨水导致方格中任意位置的水位为 t 。你可以从一个方格游向四周相邻的任意一个方格,但是前提是此时水位必 须同时淹没这两个方格。假定小C的游动是不耗时的。 现在小C从坐标方格的左上(0,0)出发。最少耗时多久他才能到达坐标方格的右下平台 (N-1, N-1)?
输入格式
第一行有一个整数N,以下是一个N*N 的方阵,代表各处的高度。
输入范围: 2 ≤ N ≤ 300 0 ≤ Height ≤ 10000000
输出格式
输出一个整数,代表最少等待时间T 样例输入
5
0 1 2 3 4
24 23 22 21 5
12 13 14 15 16
11 17 18 19 20
10 9 8 7 6
样例输出
16
样例解释
时间为16时,水位为16,此时才能保证(0,0) 和(4,4)是联通的(请自行找出一条通路)。
#include <iostream>
#include <iomanip>
using namespace std;
int n,m;
int a[310][310];
int cnt = 0;
int di[] = {0,1,0,-1};
int dj[] = {1,0,-1,0};
bool f = false;
void aaa(int,int);
int main()
{
cin>>n;
for(int i = 0;i<n;i++)
{
for(int j = 0;j<n;j++)
{
cin>>a[i][j];
}
}
cnt = a[n-1][n-1];
for(int i = 0;i<n;i++)
{
for(int j = 0;j<n;j++)
{
if(a[i][j]-a[n-1][n-1]>=0)
{
a[i][j] = a[i][j]-a[n-1][n-1];
}
else
{
a[i][j] = 0;
}
}
}
while(true)
{
aaa(0,0);
if(f==true)
{
break;
}
cnt++;
for(int i = 0;i<n;i++)
{
for(int j = 0;j<n;j++)
{
if(a[i][j]>0)
{
a[i][j]--;
}
}
}
}
cout<<cnt;
return 0;
}
void aaa(int i,int j)
{
if(i==n-1&&j==n-1)
{
f = true;
return;
}
for(int qqq = 0;qqq<4;qqq++)
{
int ti = i+di[qqq];
int tj = j+dj[qqq];
if(ti>=0&&ti<n&&tj>=0&&tj<n&&a[ti][tj]==0)
{
a[ti][tj] = -1;
aaa(ti,tj);
a[ti][tj] = 0;
}
}
return;
}
#include <iostream>
using namespace std;
int a[110][110];
int b[110][110];
int n,m;
int cnt = 0;
int cntt = 0;
int ma = -99999;
int di[] = {0,1,0,-1};
int dj[] = {1,0,-1,0};
void aaa(int,int);
int main()
{
cin>>n>>m;
for(int i = 0;i<n;i++)
{
for(int j = 0;j<m;j++)
{
cin>>a[i][j];
}
}
for(int i = 0;i<n;i++)
{
for(int j = 0;j<m;j++)
{
if(b[i][j]==0)
{
cnt++;
aaa(i,j);
ma = max(ma,cntt);
cntt = 0;
}
}
}
cout<<cnt<<endl<<ma;
return 0;
}
void aaa(int i,int j)
{
cntt++;
b[i][j] = 1;
for(int qqq = 0;qqq<4;qqq++)
{
int ti = i+di[qqq];
int tj = j+dj[qqq];
if(ti>=0&&ti<n&&tj>=0&&tj<m&&b[ti][tj]==0)
{
if(qqq==0)
{
if(a[i][j]==1||a[i][j]==2||a[i][j]==8||a[i][j]==3||a[i][j]==9||a[i][j]==10||a[i][j]==11||a[i][j]==0)
{
aaa(ti,tj);
}
}
if(qqq==1)
{
if(a[i][j]==1||a[i][j]==2||a[i][j]==4||a[i][j]==3||a[i][j]==5||a[i][j]==6||a[i][j]==7||a[i][j]==0)
{
aaa(ti,tj);
}
}
if(qqq==2)
{
if(a[i][j]==2||a[i][j]==4||a[i][j]==8||a[i][j]==6||a[i][j]==10||a[i][j]==12||a[i][j]==14||a[i][j]==0)
{
aaa(ti,tj);
}
}
if(qqq==3)
{
if(a[i][j]==1||a[i][j]==4||a[i][j]==8||a[i][j]==5||a[i][j]==9||a[i][j]==12||a[i][j]==13||a[i][j]==0)
{
aaa(ti,tj);
}
}
}
}
return;
}
#include <iostream>
using namespace std;
char a[110][110];
int n,m;
int di[] = {0,1,0,-1};
int dj[] = {1,0,-1,0};
void aaa(int,int);
int main()
{
int nn;
cin>>nn;
for(int iii = 0;iii<nn;iii++)
{
cin>>n>>m;
for(int i = 0;i<n;i++)
{
for(int j = 0;j<m;j++)
{
cin>>a[i][j];
}
}
for(int i = 0;i<n;i++)
{
if(a[i][0]=='O')
{
aaa(i,0);
}
}
for(int i = 0;i<n;i++)
{
if(a[i][m-1]=='O')
{
aaa(i,m-1);
}
}
for(int i = 0;i<m;i++)
{
if(a[0][i]=='O')
{
aaa(0,i);
}
}
for(int i = 0;i<m;i++)
{
if(a[n-1][i]=='O')
{
aaa(n-1,i);
}
}
cout<<endl;
for(int i = 0;i<n;i++)
{
for(int j = 0;j<m;j++)
{
if(a[i][j]=='O')
{
a[i][j] = 'X';
}
if(a[i][j]=='0')
{
a[i][j] = 'O';
}
cout<<a[i][j];
}
cout<<endl;
}
}
return 0;
}
void aaa(int i,int j)
{
a[i][j] = '0';
for(int qqq = 0;qqq<4;qqq++)
{
int ti = i+di[qqq];
int tj = j+dj[qqq];
if(ti>=0&&ti<n&&tj>=0&&tj<m&&a[ti][tj]=='O')
{
aaa(ti,tj);
}
}
return;
}
走迷宫
描述
一个迷宫由R行C列格子组成,有的格子里有障碍物,不能走;有的格子是空地,可 以走。 给定一个迷宫,求从左上角走到右下角最少需要走多少步(数据保证一定能走到)。
只能在水平方向或垂直方向走,不能斜着走。
输入
第一行是两个整数,R和C,代表迷宫的长和宽。
空地格子用'.'表示,有障碍物的格子用'#'表示。 迷宫左上角和右下角都是'.'
输出
输出从左上角走到右下角至少要经过多少步(即至少要经过多少个空地格子)。计算步数要包括起点和终点
样例输入
5 5
..###
#....
#.#.#
#.#.#
#.#..
样例输出
9
#include <iostream>
#include <iomanip>
using namespace std;
char a[50][50];
int n,m;
int si = 0,sj = 0,ei,ej;
int cnt = 0;
int mi = 99999;
bool f = false;
int di[] = {0,1,0,-1};
int dj[] = {1,0,-1,0};
void aaa(int,int);
int main()
{
cin>>n>>m;
for(int i = 0;i<n;i++)
{
for(int j = 0;j<m;j++)
{
cin>>a[i][j];
}
}
ei = n-1;
ej = n-1;
aaa(si,sj);
cout<<cnt;
return 0;
}
void aaa(int i,int j)
{
if(i==ei&&j==ej)
{
f = true;
return;
}
cnt++;
for(int qqq = 0;qqq<4;qqq++)
{
int ti = i+di[qqq];
int tj = j+dj[qqq];
if(ti>=0&&ti<n&&tj>=0&&tj<m&&a[ti][tj]=='.'&&f==false)
{
a[ti][tj] = '#';
aaa(ti,tj);
a[ti][tj] = '.';
}
}
return;
}