码迷,mamicode.com
首页 > Windows程序 > 详细

AcWing 842. 排列数字

时间:2019-10-25 17:56:06      阅读:310      评论:0      收藏:0      [点我收藏+]

标签:path   bsp   nbsp   cin   auto   memset   bfs   输入输出   下一步   

深搜的一道水题

https://www.acwing.com/problem/content/844/   正确输入输出

#include<bits/stdc++.h>
using 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<n; i++) {
            cout<<path[i]<<" ";
        }
        cout<<endl;
        return ;  //回溯
    }
    for(int i=1; i<=n; 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;
}

 

 

#include<bits/stdc++.h>
using namespace std;
const int N=110;
int n,m;
int g[N][N];  //地图
int d[N][N];  //到起点的距离
typedef pair<int,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(hh<=tt) {
        auto t = q[hh++];  //取出队头
        for(int i=0; i<4; i++) {
            int x=t.first+dx[i],y=t.second+dy[i];
            if(x>=0&&x<n&&y>=0&&y<m&&g[x][y]==0&&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<<x<<" "<<y<<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<n; i++)
        for(int j=0; j<m; j++)
            cin>>g[i][j];
    cout<<bfs()<<endl;
    return 0;
}

 

AcWing 842. 排列数字

标签:path   bsp   nbsp   cin   auto   memset   bfs   输入输出   下一步   

原文地址:https://www.cnblogs.com/QingyuYYYYY/p/11739199.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!