蓝桥杯 数字接龙

问题描述

小蓝最近迷上了一款名为《数字接龙》的迷宫游戏。

游戏在一个大小为 N × N 的格子棋盘上展开,其中每一个格子处都有一个 0K-1 之间的整数。

游戏规则如下:

  • 从左上角 (0, 0) 出发,目标是到达右下角 (N-1, N-1)

  • 每一步可以选择沿 水平、垂直或对角线 方向移动到下一个格子(共 8 个方向)。

  • 路径经过的棋盘格子,其上面的数字必须按顺序组成如下循环序列:

    0, 1, 2, ..., K-1, 0, 1, 2, ..., K-1, ...
    
  • 途中需要对棋盘上的 每个格子恰好经过一次(仅一次)。

  • 路径中不允许出现交叉线路

例如:若曾从 (0,0) 移动到 (1,1),则不能再从 (1,0) 移动到 (0,1),因为这样会形成交叉。

为方便表示,我们对可以行进的所有八个方向编号如下

在这里插入图片描述

因此,行进路径可以用一个包含 07 的数字字符串来表示。


输入格式

第一行包含两个整数 NK,分别表示棋盘的边长和数字序列的周期长度。

接下来 N 行,每行 N 个整数,表示棋盘格子上的数字。


输出格式

输出一行表示答案路径,用方向编号组成的字符串表示。

  • 如果存在多条合法路径,输出字典序最小的那一个;
  • 如果不存在任何合法路径,输出 -1

样例输入

3 3
0 2 0
1 1 1
2 0 2

样例输出

41255214

样例说明

行进路径如图所示,路径编号为:4 → 1 → 2 → 5 → 5 → 2 → 1 → 4


评测用例规模与约定

  • 对于 80% 的评测用例:1 ≤ N ≤ 5
  • 对于 100% 的评测用例:1 ≤ N ≤ 10, 1 ≤ K ≤ 10

c++代码

#include<iostream>
#include<vector>
#include<string>using namespace std;int N, K;vector<vector<int>> arr;
vector<vector<vector<int>>> know;
string ans = "-1", mid;void dfs(int i, int j, int msg, string ops, int lasti, int lastj) {if (ans != "-1" || i < 0 || i >= N || j < 0 || j >= N || know[i][j][0] != -1 || arr[i][j] != msg) return;mid += ops;if (i > 0 || j > 0) know[lasti][lastj][0] = i, know[lasti][lastj][1] = j;if (mid.size() == N * N - 1 && i == N - 1 && j == N - 1) {ans = mid;return;}if (msg == K - 1) msg = 0;else msg++;dfs(i - 1, j, msg, "0", i, j);if (i - 1 >= 0 && j + 1 < N && !((know[i][j + 1][0] == i - 1 && know[i][j + 1][1] == j) || (know[i - 1][j][0] == i && know[i - 1][j][1] == j + 1))) dfs(i - 1, j + 1, msg, "1", i, j);dfs(i, j + 1, msg, "2", i, j);if (i + 1 < N && j + 1 < N && !((know[i][j + 1][0] == i + 1 && know[i][j + 1][1] == j) || (know[i + 1][j][0] == i && know[i + 1][j][1] == j + 1))) dfs(i + 1, j + 1, msg, "3", i, j);dfs(i + 1, j, msg, "4", i, j);if (i + 1 < N && j - 1 >= 0 && !((know[i][j - 1][0] == i + 1 && know[i][j - 1][1] == j) || (know[i + 1][j][0] == i && know[i + 1][j][1] == j - 1))) dfs(i + 1, j - 1, msg, "5", i, j);dfs(i, j - 1, msg, "6", i, j);if (i - 1 >= 0 && j - 1 >= 0 && !((know[i][j - 1][0] == i - 1 && know[i][j - 1][1] == j) || (know[i - 1][j][0] == i && know[i - 1][j][1] == j - 1))) dfs(i - 1, j - 1, msg, "7", i, j);if (mid.size() > 0) mid.erase(mid.size() - 1);if (i > 0 || j > 0) know[lasti][lastj][0] = -1, know[lasti][lastj][1] = -1;
}int main() {cin >> N >> K;arr = vector<vector<int>>(N, vector<int>(N));know = vector<vector<vector<int>>>(N, vector<vector<int>>(N, vector<int>(2, -1)));for (int i = 0; i < N; i++) {for (int j = 0; j < N; j++) {cin >> arr[i][j];}}dfs(0, 0, 0, "", -1, -1);cout << ans;return 0;
}//by wqs

算法思路

这本质上是一道dfs搜索题

比较有难度的是如何保证不交叉

我们用一个三维数组vector<vector<vector<int>>> know;
know[i][j][0] = a, know[i][j][1] = b;
如果a == -1 && b == -1说明当前节点没有访问
否则存在一条从点(a, b)到(i,j)的有向连线。
我们根据这个数组的状态去判断是否有交叉

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/38026.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SysVinit和Systemd的系统运行级别

Linux运行级别 SysVinit系统(init守护进程)Linux系统运行级别SysVinit系统(init守护进程)查看Linux运行级别SysVinit系统(init守护进程)修改运行级别&#xff1a; Systemd守护进程Linux系统运行级别systemd查看运行级别Systemd查看系统当前运行级别 systemd修改运行级别multi-u…

SAP SD学习笔记33 - 预詑品(寄售物料),预詑品引渡(KB),预詑品出库(KE)

上一章讲了Service品目。 SAP SD学习笔记32 - Service品目(服务产品&#xff09;-CSDN博客 本章继续讲SAP SD的知识 - 预詑品(寄售物料)。 目录 1&#xff0c;预詑品概要 1-1&#xff0c;预詑品(寄售物料)的概念 1-2&#xff0c;预詑品的4种业务 1-3&#xff0c;受托品与…

DeiT:数据高效的图像Transformer及其工作原理详解

DeiT&#xff1a;数据高效的图像Transformer及其工作原理详解 随着Transformer架构在自然语言处理&#xff08;NLP&#xff09;领域的巨大成功&#xff0c;研究者们开始探索其在计算机视觉领域的应用。Vision Transformer&#xff08;ViT&#xff09;是最早将Transformer直接应…

【 <二> 丹方改良:Spring 时代的 JavaWeb】之 Spring Boot 中的异常处理:全局异常与自定义异常

<前文回顾> 点击此处查看 合集 https://blog.csdn.net/foyodesigner/category_12907601.html?fromshareblogcolumn&sharetypeblogcolumn&sharerId12907601&sharereferPC&sharesourceFoyoDesigner&sharefromfrom_link <今日更新> 一、开篇整…

【Mybatis-plus】在mybatis-plus中 if test标签如何判断 list不为空

博主介绍&#xff1a;✌全网粉丝22W&#xff0c;CSDN博客专家、Java领域优质创作者&#xff0c;掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围&#xff1a;SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…

Lineageos 22.1(Android 15)制定应用强制横屏

一、前言 有时候需要系统的某个应用强制衡平显示&#xff0c;不管他是如何配置的。我们只需要简单的拿到top的Task下面的ActivityRecord&#xff0c;并判断包名来强制实现。 二、调整wms com.android.server.wm.DisplayRotation /*** Given an orientation constant, return…

HTML网页代码预览器

HTML网页代码预览器 可以用于学习和实验HTML和CSS&#xff0c;比较方便。源码参考自网络。 功能 实时预览&#xff1a;当你在左侧的“代码编辑器”中输入代码时&#xff0c;右侧的“预览窗口”会实时显示你的网页效果&#xff08;注意&#xff0c;不能体现嵌入的JavaScript运…

Arm Linux ceres库编译

由于工作需要&#xff0c;需在国产化系统上编译ceres库&#xff0c;手上有一块树莓派&#xff0c;就在树莓派上面进行测试编译ceres库&#xff0c;总体来说比较顺利。只出现了一点小问题 参考链接&#xff1a; Ceres中文教程-安装 按照上面Linux编译过程 目录 1、在线安装依赖…

【算法学习计划】动态规划 -- 背包问题(01背包和完全背包)

目录 DP41 【模板】01背包 leetcode 416.分割等和子集 leetcode 494.目标和 leetcode 1049.最后一块石头的重量Ⅱ DP42 【模板】完全背包 leetcode 322.零钱兑换 leetcode 518.零钱兑换Ⅱ leetcode 279.完全平方数 今天&#xff0c;我们将通过 8 道题目&#xff0c;来带…

138. 随机链表的复制

题目&#xff1a; 给你一个长度为 n 的链表&#xff0c;每个节点包含一个额外增加的随机指针 random &#xff0c;该指针可以指向链表中的任何节点或空节点。 构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成&#xff0c;其中每个新节点的值都设为其对应的原节…

网络HTTPS协议

Https HTTPS&#xff08;Hypertext Transfer Protocol Secure&#xff09;是 HTTP 协议的加密版本&#xff0c;它使用 SSL/TLS 协议来加密客户端和服务器之间的通信。具体来说&#xff1a; • 加密通信&#xff1a;在用户请求访问一个 HTTPS 网站时&#xff0c;客户端&#x…

19921 多重背包

19921 多重背包 ⭐️难度&#xff1a;中等 &#x1f31f;考点&#xff1a;动态规划、背包问题 &#x1f4d6; &#x1f4da; import java.util.Arrays; import java.util.LinkedList; import java.util.Queue; import java.util.Scanner;public class Main {static int N …

C/C++蓝桥杯算法真题打卡(Day5)

一、P8772 [蓝桥杯 2022 省 A] 求和 - 洛谷 算法代码&#xff1a; #include<bits/stdc.h> // 包含标准库中的所有头文件&#xff0c;方便编程 using namespace std; // 使用标准命名空间&#xff0c;避免每次调用标准库函数时都要加 std::int main() {int n; …

【大模型基础_毛玉仁】3.5 Prompt相关应用

目录 3.5 相关应用3.5.1 基于大语言模型的Agent3.5.2 数据合成3.5.3 Text-to-SQL3.5.4 GPTs 3.5 相关应用 Prompt工程应用广泛&#xff0c;能提升大语言模型处理基础及复杂任务的能力&#xff0c;在构建Agent、数据合成、Text-to-SQL转换和设计个性化GPTs等方面不可或缺。 . …

主成分分析PCA与奇异值分解SVD

线性代数 SVD 奇异值分解&#xff08;Singular Value Decomposition&#xff0c;简称 SVD&#xff09;是线性代数中的一种基本工具&#xff0c;它将任意一个 (m * n) 矩阵 (A) 分解成三个简单矩阵的乘积&#xff0c;即 其中&#xff1a; (U) 是一个 (m*m) 的正交&#xff08…

自主代理的摩尔定律:AI 的指数级革命

图像由 Gemini 生成 前言&#xff1a;AI 正在以超过摩尔定律的速度迅速提升其自主工作能力&#xff0c;研究显示&#xff0c;AI 能够可靠完成的任务时长正以每 7 个月翻一倍的速度增长。这种指数级的发展趋势意味着&#xff0c;AI 不再只是应对简单问答或短任务的工具&#xff…

气膜文化馆:打造沉浸式文娱新空间—轻空间

演唱会、展览、音乐剧……都能办&#xff1f; 当然&#xff01;气膜文化馆不仅适用于体育赛事&#xff0c;在文化娱乐方面同样大放异彩&#xff01; 声学优化&#xff0c;打造极致听觉体验 气膜文化馆采用专业声学设计&#xff0c;避免传统场馆的回声干扰&#xff0c;提供更清…

【数据标准】数据标准化框架体系-对象类数据标准

导读&#xff1a;对象类数据标准化框架通过统一数据定义、分类和标记&#xff0c;解决数据孤岛与不一致问题&#xff0c;支撑数据分析、AI应用与合规需求。企业需结合自身业务特性&#xff0c;灵活选择国际标准&#xff08;如ISO&#xff09;、行业规范或自建体系&#xff0c;并…

【江协科技STM32】软件SPI读写W25Q64芯片(学习笔记)

SPI通信协议及S为5Q64简介&#xff1a;【STM32】SPI通信协议&W25Q64Flash存储器芯片&#xff08;学习笔记&#xff09;-CSDN博客 STM32与W25Q64模块接线&#xff1a; SPI初始化&#xff1a; 片选SS、始终SCK、MOSI都是主机输出引脚&#xff0c;输出引脚配置为推挽输出&…

C 语 言 --- 扫 雷 游 戏(初 阶 版)

C 语 言 --- 扫 雷 游 戏 初 阶 版 代 码 全 貌 与 功 能 介 绍扫雷游戏的功能说明游 戏 效 果 展 示游 戏 代 码 详 解game.htest.cgame.c 总结 &#x1f4bb;作 者 简 介&#xff1a;曾 与 你 一 样 迷 茫&#xff0c;现 以 经 验 助 你 入 门 C 语 言 &#x1f4a1;个 人 主…