赞
踩
红与黑
题目描述
有一间长方形的房子,地上铺了红色、黑色两种颜色的正方形瓷砖。你站在其中一块黑色的瓷砖上,只能向相邻的黑 色瓷砖移动。请写一个程序,计算你总共能够到达多少块黑色的瓷砖。
输入
包括多组数据。每组数据的第一行是两个整数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;
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。