输出所有路径 P137

简介: 输出所有路径 P137

//dfs暴搜所有路径
//蓝桥杯算法竞赛p137
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#define endl "\n"
using namespace std;
const int N = 15;
int n,l;
char m[N][N];
string p[N][N];//i到j的路径记录
int x1 , x2 , y1, y2;
int sx , sy, tx, ty;
int dx[] = {-1,0,1,0};
int dy[] = {0,1,0,-1};
int num;
void dfs(int x , int y){
    for(int i = 0 ; i < 4 ; i ++){
        int nx = x + dx[i] , ny = y + dy[i];
        if(nx >= n || nx < 0 || ny >= l || ny < 0 ) continue ;//走出地图,超范围了
        if(m[nx][ny] == '*'){//遇到终点         
            num ++ ;//路径加一
            char  t[4]; sprintf(t,"%d%d",nx,ny);//把整数变量变成字符串变量
            cout << num << ": " << p[x][y] << "->" << t << endl ;//输出路径
            //会有覆盖
            continue ;
        }
        if(m[nx][ny] == '.'){
            m[nx][ny] = '#';//标记已经走过
            char t[4] ; sprintf(t,"%d%d",nx,ny);
            p[nx][ny] = p[x][y] + "->" + t ;//记录路径
            dfs(nx,ny);
            m[nx][ny] = '.';
        }
    }
}
 
 
int main(){
    cin >> l >> n ;
    for(int i = 0 ; i < l ; i ++){
        for(int j = 0 ; j < n ; j ++){
            cin >> m[j][i] ;
            if(m[j][i] == '@') { sx = j ; sy = i ;}
            if(m[j][i] == '*') { tx = j ; ty = i ;}
        }
    }
    cout << "from" << sx << sy << " to " << tx << ty << endl ;//记录起点
    char t[4] ;  sprintf(t,"%d%d",sx , sy); p[sx][sy] = t;
    dfs(sx,sy);
    return 0;
}
 
目录
相关文章
|
9天前
|
IDE 开发工具 iOS开发
Python编程案例:查找指定文件大小的文件并输出路径
Python编程案例:查找指定文件大小的文件并输出路径
15 3
|
22天前
路径拼接和系统判断
路径拼接和系统判断
|
3月前
输出到一个新文件C中
【7月更文挑战第9天】输出到一个新文件C中。
47 13
|
5月前
如何快速提取出一个文件里面全部指定类型的文件的全部路径
该文介绍了如何使用一个工具进行文件批量复制。工具可以从百度网盘(提取码:qwu2)或蓝奏云(提取码:2r1z)下载。打开工具后切换到第五模块,使用Ctrl+5快捷键进入文件批量复制功能。点击“搜索添加”,选择要搜索的文件夹(如PS文件夹),勾选搜索全部子文件,然后开始搜索。搜索完成后,会显示所有结果。
|
4月前
|
C++
C++ 获取当前程序路径
C++ 获取当前程序路径
|
5月前
|
Linux Shell
Linux脚本获取输入参数判断文件还是文件路径
Linux脚本获取输入参数判断文件还是文件路径
32 4
|
C++
VS配置QtTools的路径时报“路径中具有非法字符”错误
VS配置QtTools的路径时报“路径中具有非法字符”错误
277 0
|
C++
全网首发:VS编译出错:两个输出文件名解析为同一个输出路径
全网首发:VS编译出错:两个输出文件名解析为同一个输出路径
432 0
|
JavaScript Linux vr&ar
通过path模块进行路径拼接|学习笔记
快速学习通过path模块进行路径拼接
274 0
通过path模块进行路径拼接|学习笔记
|
机器人
Day39——62.不同路径 63. 不同路径 II
Day39——62.不同路径 63. 不同路径 II
78 0