AcWing 842. 排列数字
标签:path bsp nbsp cin auto memset bfs 输入输出 下一步
深搜的一道水题
https://www.acwing.com/problem/content/844/ 正确输入输出
#includeusing namespace std;
const int N=10;
int path[N];
bool vis[N];
int n;
void dfs(int u) {
if(u==n) {
for(int i=0; i) {
cout" ";
}
coutendl;
return ; //回溯
}
for(int i=1; i) {
if(!vis[i]) { //如果访问过
vis[i]=1; //标记
path[u]=i; //记录此时的数字
dfs(u+1); //下一步
vis[i]=0; //清理现场
path[u]=0;
}
}
}
int main() {
cin>>n;
dfs(0);
return 0;
}
#includeusing namespace std;
const int N=110;
int n,m;
int g[N][N]; //地图
int d[N][N]; //到起点的距离
typedef pairint,int>PII;
PII q[N*N];//pair
PII Prev[N][N]; //用来记录x,y 这个点从哪个点过来,并输出路径
int bfs() {
int hh=0,tt=0; //hh 队头 ,tt 队尾
q[0]= {0,0};
memset(d,-1,sizeof d); //初始化
d[0][0]=0; //起点到起点的距离为0
int dx[4]= {-1,0,1,0}, dy[4] = {0,1,0,-1};
while(hhtt) {
auto t = q[hh++]; //取出队头
for(int i=0; i4; i++) {
int x=t.first+dx[i],y=t.second+dy[i];
if(x>=0&&x=0&&y0&&d[x][y]==-1) { //为空地不是障碍物,而且没有走过,
Prev[x][y]=t; //记录从哪个个点过来
d[x][y]=d[t.first][t.second]+1; //标记距离
q[++tt]= {x,y}; //在放进去
}
}
}
int x=n-1,y=m-1;
while(x||y) {
cout" "endl;
auto t=Prev[x][y];
x=t.first,y=t.second; //输出路径
}
return d[n-1][m-1];
}
int main() {
cin>>n>>m;
for(int i=0; i)
for(int j=0; j)
cin>>g[i][j];
coutendl;
return 0;
}
AcWing 842. 排列数字
标签:path bsp nbsp cin auto memset bfs 输入输出 下一步
原文地址:https://www.cnblogs.com/QingyuYYYYY/p/11739199.html
评论