蓝桥真题--路径之谜DFS解法

路径之谜

思路

在这里插入图片描述

  • 前置知识:深度搜索模板
  • 搜索所有可以找的路径,将走过的靶子减去一
  • 走到最后一个格子的时候,直接去判断所有的靶子
  • 只有除最后一个位置的靶子,其余靶子都归零的时候,判断一个最后一个位置横坐标和纵坐标的靶子
  • 如果这两个靶子都是1,是我们要的答案,输出路径
  • 每次走过一个格子,都将对应的坐标存入一个path数组中,回溯时就将他复原回去
  • 对于其他状态也需要进行复原,美名其曰-恢复现场

Coding

#include <iostream>
#include <vector>
using namespace std;
const int N = 21;
int vx[] = {0,0,1,-1};
int vy[] = {1,-1,0,0};
int xba[N];
int yba[N];
int path[N*N];
int n, idx;
bool st[N][N];

inline void dfs(int x, int y) {
	if (x == n-1 && y == n-1) {
		for (int i = 0; i < n-1; i++) {
			if (xba[i] || yba[i]) return;
		}
		if (xba[n-1] == 1 && yba[n-1] == 1) {
			path[idx ++] = n*y+x;
			for (int j = 0; j < idx; j++) {
				cout << path[j] << ' ';
			}cout << endl;
		}
	}
	for (int i = 0; i < 4; i++) {
		int nx, ny;
		nx = x + vx[i], ny = y + vy[i];
		if (x >= 0 && y >= 0 && x < n && y < n && !st[x][y]) {
			st[x][y] = true;
			xba[x]--;
			yba[y]--;
			path[idx ++] = n*y+x;
			dfs(nx, ny);
			xba[x]++;
			yba[y]++;
			idx--;
			st[x][y] = false;
		}
	}
}

int main() {
	cin >> n;
	for (int i = 0; i < n; i++) {
		cin >> xba[i];
	}
	for (int i = 0; i < n; i++) {
		cin >> yba[i];
	}
	dfs(0, 0);
}

相关推荐

  1. 杯历年DFS

    2024-04-06 23:48:03       13 阅读
  2. 2023杯省赛分糖果 |枚举+DFS

    2024-04-06 23:48:03       27 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-06 23:48:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-06 23:48:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-06 23:48:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-06 23:48:03       20 阅读

热门阅读

  1. 【DevOps工具篇】Keycloak安装配置及脚本化

    2024-04-06 23:48:03       16 阅读
  2. composer常见错误解决

    2024-04-06 23:48:03       14 阅读
  3. Docker in Docker原理与实战

    2024-04-06 23:48:03       13 阅读
  4. 移动点的函数

    2024-04-06 23:48:03       15 阅读
  5. 使用神经网络识别病毒序列

    2024-04-06 23:48:03       13 阅读
  6. cmake学习笔记2

    2024-04-06 23:48:03       14 阅读
  7. 渗透测试、人肉搜索算不算犯罪?

    2024-04-06 23:48:03       15 阅读
  8. RabbitMQ死信队列

    2024-04-06 23:48:03       16 阅读
  9. react组件:strictmode

    2024-04-06 23:48:03       15 阅读