首页 > 其他分享 >蓝桥杯-路径之谜

蓝桥杯-路径之谜

时间:2023-01-29 23:14:04浏览次数:47  
标签:tx ty int 路径 蓝桥 ++ row col 之谜

问题描述
小明冒充 X 星球的骑士,进入了一个奇怪的城堡,城堡里边什么都没有,只有方形石头铺成的地面。

假设城堡地面是 n x n 个方格,如图所示。

 

 


按习俗,骑士要从西北角走到东南角,可以横向或纵向移动,但不能斜着走,也不能跳跃。

每走到一个新方格,就要向正北方和正西方各射一箭。(城堡的西墙和北墙内各有 n 个靶子)

同一个方格只允许经过一次,但不必走完所有的方格。

如果只给出靶子上箭的数目,你能推断出骑士的行走路线吗?有时是可以的,比如图中的例子。

本题的要求就是已知箭靶数字,求骑士的行走路径(测试数据保证路径唯一)

输入格式
第一行一个整数 N,表示地面有 N x N 个方格 (0 < N < 20)
第二行 N 个整数,空格分开,表示北边的箭靶上的数字(自西向东)
第三行 N 个整数,空格分开,表示西边的箭靶上的数字(自北向南)

输出格式
一行若干个整数,表示骑士路径。

为了方便表示,我们约定每个小格子用一个数字代表,从西北角开始编号: 0, 1, 2, 3…
比如,图中的方块编号为:

0 1 2 3
4 5 6 7
8 9 10 11
12 13 14 15

样例输入
4
2 4 3 4
4 3 3 3

样例输出
0 4 5 1 2 3 7 11 10 9 13 14 15
这题可以使用dfs进行解决

#include <iostream>
using namespace std;

const int N = 22;
int col[N];
int row[N];
int g[N][N];
int ans[1000];
int count = 0;
int n;
//判断col和row是否被清空 bool check() { for(int i = 0;i < n;i++) { if (col[i] != 0 || row[i] != 0) { return false; } } return true; } int dx[4] = {1,0,-1,0}; int dy[4] = {0,1,0,-1}; void dfs(int x,int y) {
  //走到终点,并且col和row数组满足要求,救输出结果 if (x == n - 1 && y == n - 1) { if (check()) { for(int i = 0;i <count;i++) { cout << ans[i] << " "; } } }
//dfs搜索 int tx,ty; for(int i = 0;i < 4;i++) { tx = x + dx[i]; ty = y + dy[i]; if (tx >= 0 && tx < n && ty >= 0 && ty < n && g[tx][ty] == 0 && col[ty] && row[tx]) { g[tx][ty] = 1; col[ty]--; row[tx]--; ans[count++] = n * tx + ty; dfs(tx,ty); col[ty]++; row[tx]++; g[tx][ty] = 0; count--; } } } int main() { cin >> n; for(int i = 0;i < n;i++) { cin >> col[i]; } for(int i = 0;i < n;i++) { cin >> row[i]; } //从(0,0)触发,此点已被访问 g[0][0] = 1; ans[count++] = 0; col[0]--; row[0]--; dfs(0,0); return 0; }

 

标签:tx,ty,int,路径,蓝桥,++,row,col,之谜
From: https://www.cnblogs.com/polang19/p/17074053.html

相关文章

  • 蓝桥杯-全球变暖
    你有一张某海域NxN像素的照片,"."表示海洋、"#"表示陆地,如下所示:........##.....##........##...####....###........其中"上下左右"四个方向上连在一起的一片陆......
  • 蓝桥杯-跳跃
    题目 小蓝在一个n行m列的方格图中玩一个游戏。 开始时,小蓝站在方格图的左上角,即第1行第1列。 小蓝可以在方格图上走动,走动时,如果当前在第r行第c列,他不......
  • 蓝桥杯备战日志(Python)2-相乘(逆向枚举)
    原题小蓝发现,他将  至  之间的不同的数与  相乘后再求除以  的余数,会得到不同的数。小蓝想知道,能不能在  至  之间找到一个数,与  相乘后再除以  后的余数......
  • 过滤器拦截路径配置以及过滤器拦截方式配置和过滤器链
    过滤器拦截路径配置1.具体资源路径:/index.jsp只有访问index.jsp资源时,过滤器才会被执行2.拦截目录:/user/*访问/user下的所有资源时,过滤器都会被执行3.后......
  • 257. 二叉树的所有路径
    问题描述https://leetcode.cn/problems/binary-tree-paths/description/解题思路叶子结点时,添加到结果序列即可。代码#Definitionforabinarytreenode.#class......
  • 即席留存、漏斗、路径等分析参考
    Clickhouse(流量分析(一).漏斗分析案例)每天数百亿用户行为数据,美团点评怎么实现秒级转化分析?(美团漏斗转化分析)clickhouse数据模型之留存分析 clickhouse数据模型之用......
  • 蓝桥杯 易错题 赢球票
    题目描述某机构举办球票大奖赛。获奖选手有机会赢得若干张球票。主持人拿出 N 张卡片(上面写着 1⋯⋯N 的数字),打乱顺序,排成一个圆圈。你可以从任意一张卡片开始顺时......
  • 蓝桥杯 统计子矩阵
    题目描述给定一个N×M的矩阵A,请你统计有多少个子矩阵(最小1×1,最大N×M)满足子矩阵中所有数的和不超过给定的整数K? 输入格式第一行包含三个整......
  • 基于PSO粒子群优化算法的TSP路径规划matlab仿真
    1.算法描述粒子群优化算法(PSO),粒子群中的每一个粒子都代表一个问题的可能解,通过粒子个体的简单行为,群体内的信息交互实现问题求解的智能性。在求解TSP这种整数规划问题......
  • 基于PSO粒子群优化算法的TSP路径规划matlab仿真
    1.算法描述       粒子群优化算法(PSO),粒子群中的每一个粒子都代表一个问题的可能解,通过粒子个体的简单行为,群体内的信息交互实现问题求解的智能性。      ......