每日总结(2022/1/9)
作者:互联网
由于昨晚太晚睡觉,今早昏昏沉沉。。。之前还说早点睡来着,但也不是没有收获的
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