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

路径之谜

思路

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

Coding

c 复制代码
#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);
}
相关推荐
欧阳小猜2 小时前
深度学习②【优化算法(重点!)、数据获取与模型训练全解析】
人工智能·深度学习·算法
小欣加油2 小时前
leetcode 904 水果成篮
c++·算法·leetcode
有Li2 小时前
CXR-LT 2024:一场关于基于胸部X线的长尾、多标签和零样本疾病分类的MICCAI挑战赛|文献速递-深度学习人工智能医疗图像
论文阅读·人工智能·算法·医学生
君万2 小时前
【LeetCode每日一题】56. 合并区间
算法·leetcode·golang
墩墩同学2 小时前
【LeetCode题解】LeetCode 287. 寻找重复数
算法·leetcode·二分查找
小南家的青蛙2 小时前
LeetCode第55题 - 跳跃游戏
算法·leetcode·职场和发展
啊我不会诶3 小时前
CF每日4题(1500-1700)
c++·学习·算法
shuououo4 小时前
集成算法学习笔记
笔记·学习·算法
呼啸长风5 小时前
漫谈散列函数
算法
NAGNIP5 小时前
彻底搞懂 RoPE:位置编码的新范式
算法