标签:总结 10 终点 int 每日 迷宫 坐标 2022 起点
由于昨晚太晚睡觉,今早昏昏沉沉。。。之前还说早点睡来着,但也不是没有收获的
1.上午(3h) 在某站又看了一些关于搜索的视频,迷宫都忘的差不多了,所以重新将迷宫代码码了一遍,漏洞百出,强行3h才20%
2.下午(2h) 再接再厉终于将迷宫100%了。下面给大家初学者做的简单迷宫
题目背景
给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过。给定起点坐标和终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案。在迷宫中移动有上下左右四种方式,每次只能移动一个方格。数据保证起点上没有障碍。
题目描述
无
输入格式
第一行N、M和T,N为行,M为列,T为障碍总数。第二行起点坐标SX,SY,终点坐标FX,FY。接下来T行,每行为障碍点的坐标。
输出格式
给定起点坐标和终点坐标,问每个方格最多经过1次,从起点坐标到终点坐标的方案总数。
输入输出样例
输入 #1复制
2 2 1 1 1 2 2 1 2
输出 #1复制
1
说明/提示
【数据规模】
1≤N,M≤5
话不多说,下面是代码
#include<stdio.h>
int x,y;
int endx,endy,startx,starty,cot=0;
int map[10][10];//地图
int vis[10][10]={0};//标记
int fx[4]={0,0,1,-1};//用来移动
int fy[4]={1,-1,0,0};
void dfs(int x,int y)
{
if(x==endx&&y==endy)//到达终点方案数加一
{
cot++;
return ;//回溯
}
else
{
for(int i=0;i<=3;i++)//开始搜索
{
if(map[x+fx[i]][y+fy[i]]==1&&vis[x+fx[i]][y+fy[i]]==0)
{
vis[x][y]=1;//标记来过的点
dfs(x+fx[i],y+fy[i]);//接着搜索
vis[x][y]=0;//回溯后清除标记
}
}
}
}
int main()
{
int x1,y1,n;
int N,M;//地图大小
scanf("%d %d %d",&N,&M,&n);//n为障碍个数
for(int i=1;i<=N;i++)
{
for(int j=1;j<=M;j++)
{
map[i][j]=1;//全部标记为1
}
}
scanf("%d %d %d %d",&startx,&starty,&endx,&endy);//输入起点和终点
vis[startx][starty]=1;//起点标记
for(int i=0;i<n;i++)
{
scanf("%d %d",&x1,&y1);//输入障碍的坐标
map[x1][y1]=0;//标记为0
}
dfs(startx,starty);//初始
printf("%d",cot);//输出方案个数
}
3.
标签:总结,10,终点,int,每日,迷宫,坐标,2022,起点 来源: https://blog.csdn.net/weixin_62494553/article/details/122392872
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。