Cracking the Safe

2024-08-31 10:12
文章标签 safe cracking

本文主要是介绍Cracking the Safe,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
原题链接:https://leetcode.cn/problems/cracking-the-safe/description/

题目要求的是,某个时刻能够打开保险箱的任一最短密码序列,需要包含所有密码子串。
答案应当是一个字符串,任意长度为n的子串的都是一种密码方案。
对于有n位,每位k种方案的密码串,共有k^n个。
题目要求最短,那么任意位置选出的子串应当是不重复的。
也就是说,一个长度为n的滑动窗口,在移动k^n次后,应得到k^n个不同的密码串。
一次滑动得到的两个不同密码串,前者的n-1位后缀是后者的n-1位前缀。
题目要求长度为n,将长度为n-1k^(n-1)个串作为图的节点。
通过追加[0,k),可以得到k^n个密码串,每个串的后n-1位子串一定等于图中的某个节点。在追加字符前前的子串,和,追加字符后的子串的后n-1位子串,之间,建立一条有向边。

  • 那么图中的每个节点都有k条出边,指向k个不同的图中节点。
  • k个图中节点一定是不同的,因为最后一个字符,也就是新追加的字符,是不相等的。

对于任意节点a1a2...aiaj,通过在xa1a2...ai末尾追加最后一个字符aj取后缀后得到,首位被舍弃。
首位有[0,k)k种情况,任意节点都有k的可选的状态来源:

  • 那么图中的每个节点都有k条入边,来自k个不同的图中节点。

那么图中的每个点,都有k条出边和入边。
那么任意节点出发,都有一条欧拉回路。
最暴力的写法是,枚举每一位所有可能的情况,将k^n个密码串拼接。但必然不是最短方案。
因为一定有密码串满足一者的后缀等于另一者的前缀,可以借此压缩密码串长度。

dfs过程分析

状态表示node

  • 集合:已经生成的串,的末尾n-1个字符的状态压缩表示为node
  • 属性:从node出发的最短序列

状态转移:

  • 当前状态表示为node,是一个长度为n-1的数字,表示最后n-1位数字。
  • 在状态的末尾添加一个k进制数字x,形成一个新的n位序列。

去重和记忆化:

  • 通过set<int> seen,记录所有已经访问过的状态,确保每个状态只被访问一次。
  • 通过nei % highset,取出新状态的高n-1位部分,如此递归,直到所有状态都被遍历。

字符串拼接:

  • 在递归过程中,每当成功生成了一个新的状态,就将对应的x,即当前状态后添加的数字,转化为字符,并将其添加到最终答案字符串中。
  • 最后追加n-1'0',表示起点,因为Hierholzer算法求的路径是逆序的。
class Solution {
public:string crackSafe(int n, int k) {int highset = pow(10, n - 1);set<int> seen;string ans;auto dfs = [&](auto dfs, int node) -> void {for (int x = 0; x < k; x++) {int nei = node * 10 + x;if (!seen.count(nei)) {seen.insert(nei);dfs(dfs, nei % highset);ans += x + '0';}}};dfs(dfs, 0);ans += string(n - 1, '0');return ans;}
};

这篇关于Cracking the Safe的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1123609

相关文章

每天一道面试题(2):fail-safe 机制与 fail-fast 机制分别有什么作用?

当谈论Java集合的 fail-fast 和 fail-safe 机制时,涉及的是在集合被并发修改时的行为和处理方式。这些机制对保证程序的正确性和稳定性非常重要,尤其是在多线程环境中。 1. Fail-Fast 机制 定义: Fail-fast 机制的核心是在检测到集合在遍历过程中被修改时,立即抛出 ConcurrentModificationException 异常,从而中断迭代操作。这种

解决PHP Warning: strftime(): It is not safe to rely on the system's timezone set

当运行一些程序时,在httpd日志中会有如下警告日志: PHP Warning:  strftime(): It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set(

[Meachines] [Easy] Safe BOF+ROP链+.data节区注入BOF+函数跳转BOF+KeePass密码管理器密码破译

信息收集 IP AddressOpening Ports10.10.10.147TCP:22,80,1337 $ nmap -p- 10.10.10.147 --min-rate 1000 -sC -sV PORT STATE SERVICE VERSION22/tcp open ssh OpenSSH 7.4p1 Debian 10+deb9u6 (protocol

Name node is in safe mode

启动hive时会因为安全模式导致hive启动不了,如下图所示: 那就需要将安全模式进行关闭;使用如下命令:hadoop dfsadmin -safemode leave 这样就可以启动成功了;

Is my business data safe in cloud? NetSuite到底安全吗?

NetSuite 产品群QQ:779253701 73% companies are planning to move to cloud in 2 years. Why? Oracle + NetSuite, 4 powerful layers of security 1. Multiple Redundant Oracle Data Centers. Your informati

UVa 991 Safe Salutations 卡特兰数

题目来源:UVa 991 Safe Salutations 题意:圆上2*n个点均匀分布 两两相连 求不相交的方案数 思路:卡特兰数的应用 以下总结转自某大牛 /*最典型的四类应用:(实质上却都一样,无非是递归等式的应用,就看你能不能分解问题写出递归式了)1.括号化问题。矩阵链乘: P=a1×a2×a3×……×an,依据乘法结合律,不改变其顺序,只用括号表示成对的乘积,试问有几种括号化

{ Cracking The Coding Interview: 150 programming QA } --- Arrays and Strings

Hashtable, ArrayList (Dynamically resizing array, providing O(1) access), StringBuffer (do string concatenation) 1. 判断string是否有重复字符,不允许使用其他数据结构。 Step 1: 问清楚限制,string的编码是ASCII还是Unicode a. 如果可以用其他数

uva 825 Walking on the Safe Side(动态规划:记忆化搜索)

题目的输入太蛋疼了... 题目本身倒是不难 代码如下: #include <cstdio>#include <cstring>#include <iostream>#include <algorithm>#define MAXN 1010using namespace std;char str[MAXN];int a[MAXN][MAXN], dp[MAXN][MAXN];i

mysqld_safe Directory '/var/lib/mysql' for UNIX socket file don't exists.

在Linux<CentOS>服务器上安装Mysql,由于Centos自身的yum源中用Mysql的分支Mariadb代替了MySQL,所以不得不选择rpm或tar.gz包的方式安装, 但是为了以后在其他LInux如Ubuntu中也能熟练安装MySQL,所以推荐使用tar.gz,安装教程—http://blog.csdn.net/qq_32331073/article/details/762525

大规模敏捷SA(Leading SAFe)证书是什么意思?如何报名,含金量高吗?

大规模敏捷SA(Leading SAFe)证书是什么意思? 常规的敏捷框架适用于中小型项目团队,而且不具有扩展性。基于常规的敏捷框架,SAFe定义了一个可扩展的敏捷框架模型,它适用于大型团队的合作开发,可以提高团队之间的协作性,降低团队管理的复杂性。 SAFe是目前国际上最流行的规模化敏捷方法,将敏捷实践从团队级(team level)有效扩展到项目群级(program level)乃至企业级