Mike同学在为扫地机器人设计一个在矩形区域中行走的算法,Mike是这样设计的:先把机器人放在出发点(1,1)点上,机器人在每个点上都会沿用如下的规则来判断下一个该去的点是哪里。规则:优先向右,如果向右不能走(比如:右侧出了矩形或者右侧扫过了)则尝试向下,向下不能走则尝试向左,向左不能走则尝试向上;直到所有的点都扫过。
Mike为了验证自己设计的算法是否正确,打算先模拟一下这个算法,每当机器人走过一个单元格时,会在单元格内标记一个数字,这个数字从1开始,每经过一个单元格数字会递增1,直到所有的单元格都扫一遍,也就是所有的单元格都标记过数字,机器人会自动停止。 比如:如果机器人按照上面的规则,清扫一个3 * 4大小的矩形区域,那么标记数字的结果如下图所示。
再比如:如果机器人按照上面的规则,清扫一个5 * 5大小的矩形区域,那么标记数字的结果如下图所示。
请你帮助Mike设计一个程序,按照上面的规则,将一个n * m大小的矩形,标记一下数字,输出最终标记的结果。
输入
一行内有2个两个整数n和m,用空格隔开,分别代表矩形区域的行数(高)和列数(宽)(n和m都是2~9之间的整数)
输出
输出按题意机器人走过每个点之后,标记数字的结果,每个数字输出时场宽设置为3。
样例
输入
3 4
输出
1 2 3 4
10 11 12 5
9 8 7 6
分析 :1、机器人每走一格格子里的数就比上一个格子里的数大一
2、机器人走的方向是先右再下再左再上的优先级考虑
3、输出时字符宽度为3要使用iomanip头文件中的setw函数
4、范围2~9
代码如下:
#include<iostream>
using namespace std;
const int N=10;
int n,m;
int g[N][N];//用地图保存
void dfs(int x,int y,int temp)
{
g[x][y]=temp;//把第一个格子填上一
if(y+1<=m && a[x][y+1]==0) dfs(x,y+1,temp++); //向右
if(x+1<=n && a[x+1][y]==0) dfs(x+1,y,temp++);//向下
if(y-1>=1 && a[x][y-1]==0) dfs(x,y-1,temp++);//向左
if(x-1>=1 && a[x-1][y]==0) dfs(x-1,y,temp++);//向上
}
int main()
{
cin>>n>>m;//输入规模
//开始走路
int temp=1;//第一格标记为一
dfs(1,1,temp);
for(int i=1;i<=n;i++)//输出格子
{
for(int j=1;j<=m;j++)
cout<<g[i][j]<<" ";
cout<<endl;
}
return 0;
}