- 数据很小10x10直接dfs,搜索树深度<=5,每一层枚举每辆车向4个方向走的方案
- 递归枚举每辆车,每辆车都有4个方向,当递归深度==K时判断是否有车停在目标点
#define debug #ifdef debug #include <time.h> #include "/home/majiao/mb.h" #endif #include <iostream> #include <algorithm> #include <vector> #include <string.h> #include <map> #include <set> #include <stack> #include <queue> #define MAXN ((int)1e5+7) #define ll long long int #define QAQ (0) #include <sstream> using namespace std; int n, m, K; int dr[] = { 1, -1, 0, 0 }; //4个方向 int dc[] = { 0, 0, 1, -1 }; char mtx[16][16], tmp[16][16]/*用来模拟车的位置(0没有车,1有车)*/; struct Node { int r, c; } ; bool check(int x, int y) { //判断是否越界 return mtx[x][y]; } bool ok = false; void dfs(int level, vector<Node> v) { if(ok) return ; if(level == K) { //第level步恰好有在目标格子的车就ok=true for(int i=1; i<=n; i++) for(int k=1; k<=m; k++) if(tmp[i][k] && mtx[i][k]=='D') { ok = true; goto p; } p: return ; } for(int i=0; i<int(v.size()) && !ok; i++) { //枚举每辆车 Node& no = v[i]; //每辆车都有4个方向 for(int k=0; k<4 && !ok; k++) { int tmpr = no.r, tmpc = no.c; //移动到这个方向,直到撞墙或撞车 while(check(no.r+dr[k], no.c+dc[k]) && (mtx[no.r+dr[k]][no.c+dc[k]]!='X') && !(tmp[no.r+dr[k]][no.c+dc[k]])) { no.r += dr[k], no.c += dc[k]; } tmp[no.r][no.c] = true; tmp[tmpr][tmpc] = false; dfs(level+1, v); //递归下一步 tmp[no.r][no.c] = false; //还原现场 tmp[tmpr][tmpc] = true; no.r = tmpr, no.c = tmpc; } } } int main() { #ifdef debug freopen("test", "r", stdin); clock_t stime = clock(); #endif scanf("%d %d %d ", &m, &n, &K); vector<Node> vec; for(int i=1; i<=n; i++) { scanf("%s ", mtx[i]+1); for(int k=1; k<=m; k++) if(mtx[i][k] == 'R') vec.push_back({i, k}); } dfs(0, vec); printf("%s\n", ok ? "YES" : "NO"); #ifdef debug clock_t etime = clock(); printf("rum time: %lf 秒\n",(double) (etime-stime)/CLOCKS_PER_SEC); #endif return 0; }