蓝桥真题--路径之谜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);
}
相关推荐
pianmian13 小时前
python数据结构基础(7)
数据结构·算法
好奇龙猫5 小时前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法
sp_fyf_20246 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
香菜大丸6 小时前
链表的归并排序
数据结构·算法·链表
jrrz08286 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time6 小时前
golang学习2
算法
南宫生7 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步8 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
Ni-Guvara8 小时前
函数对象笔记
c++·算法
泉崎8 小时前
11.7比赛总结
数据结构·算法