深度搜索算法2(c++)

红与黑

题目描述

有一间长方形的房子,地上铺了红色、黑色两种颜色的正方形瓷砖。你站在其中一块黑色的瓷砖上,只能向相邻的黑 色瓷砖移动。请写一个程序,计算你总共能够到达多少块黑色的瓷砖。

输入

包括多组数据。每组数据的第一行是两个整数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;
}

相关推荐

  1. C++中的深度优先搜索算法

    2024-06-12 13:40:07       31 阅读
  2. 深度优先搜索算法C实现

    2024-06-12 13:40:07       14 阅读
  3. c语言算法深度优先搜索(n皇后问题)

    2024-06-12 13:40:07       14 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-12 13:40:07       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-12 13:40:07       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-12 13:40:07       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-12 13:40:07       20 阅读

热门阅读

  1. 为什么选择Scala?大数据开发从入门到精通

    2024-06-12 13:40:07       8 阅读
  2. iPadOS 18支持的设备列表

    2024-06-12 13:40:07       7 阅读
  3. Python基础学习笔记(十)——初探正则

    2024-06-12 13:40:07       7 阅读
  4. QT 中文乱码 以及 tr 的使用

    2024-06-12 13:40:07       6 阅读
  5. 【docker实战】如何登陆到自己的私有仓库?

    2024-06-12 13:40:07       10 阅读
  6. vue获取用户的mac地址

    2024-06-12 13:40:07       7 阅读
  7. oracle 查询分隔符分隔开的所有数据

    2024-06-12 13:40:07       6 阅读
  8. 了解 XML HttpRequest 及其在 Web 开发中的应用

    2024-06-12 13:40:07       11 阅读