当前位置: 首页 > wzjs >正文

揭阳网站制作永久免费crm客户管理系统

揭阳网站制作,永久免费crm客户管理系统,手机移动开发网站建设,潍坊网站建设定制题目描述 有一个需要密码才能打开的保险箱。密码是 n 位数, 密码的每一位都是范围 [0, k - 1] 中的一个数字。 保险箱有一种特殊的密码校验方法,你可以随意输入密码序列,保险箱会自动记住 最后 n 位输入 ,如果匹配,则能够打开保…

题目描述 

有一个需要密码才能打开的保险箱。密码是 n 位数, 密码的每一位都是范围 [0, k - 1] 中的一个数字。

保险箱有一种特殊的密码校验方法,你可以随意输入密码序列,保险箱会自动记住 最后 n 位输入 ,如果匹配,则能够打开保险箱。

  • 例如,正确的密码是 "345" ,并且你输入的是 "012345" :
    • 输入 0 之后,最后 3 位输入是 "0" ,不正确。
    • 输入 1 之后,最后 3 位输入是 "01" ,不正确。
    • 输入 2 之后,最后 3 位输入是 "012" ,不正确。
    • 输入 3 之后,最后 3 位输入是 "123" ,不正确。
    • 输入 4 之后,最后 3 位输入是 "234" ,不正确。
    • 输入 5 之后,最后 3 位输入是 "345" ,正确,打开保险箱。

在只知道密码位数 n 和范围边界 k 的前提下,请你找出并返回确保在输入的 某个时刻 能够打开保险箱的任一 最短 密码序列 。

示例 1:

输入:n = 1, k = 2
输出:"10"
解释:密码只有 1 位,所以输入每一位就可以。"01" 也能够确保打开保险箱。

示例 2:

输入:n = 2, k = 2
输出:"01100"
解释:对于每种可能的密码:
- "00" 从第 4 位开始输入。
- "01" 从第 1 位开始输入。
- "10" 从第 3 位开始输入。
- "11" 从第 2 位开始输入。
因此 "01100" 可以确保打开保险箱。"01100"、"10011" 和 "11001" 也可以确保打开保险箱。

题意转化
首先对题意进行转化和抽象,具体方式类似官方题解,即将所有的 n−1 位数作为节点。每个节点有 k 条边,节点上添加数字 0∼k−1 视为一条边。

举例说明,如 n=3,k=2(三位二进制数),其节点(二位二进制数)为 “00”,“01”,“10”,“11”,每个节点有 2 条边,节点上添加数字 0∼1 可转化到自身或另一个节点,如下图所示。

如果我们从任一节点出发,能够找出一条路径,经过图中的所有边且只经过一次,然后把边上的数字写入字符串(还需加入起始节点的数字),那么这个字符串显然符合要求,而且找不出比它更短的字符串了。

贪心构造算法
当我们无路可走时,一定是在起始点,并且起始点的所有边都已经过。 这是因为所有节点的入度和出度均为 k。如果我们不在起始点,那 “只要有进去的路,就一定还有至少一条出去的路”。

再看之前出现的无路可走的情况(下图),我们发现,起始点回的太早了。从贪心的角度来想,如果可以 尽可能晚返回起始点,就能遍历更多的边。

如果实现这个算法呢?很简单,稍微改动之前的算法即可。我们选择 “00” 作为起始点。但是每次要选择添加的数字时,从大数字开始(即从 k−1 遍历到 0)。这样可以尽可能晚地回到起始点。

 代码:

class Solution {
public:string crackSafe(int n, int k) {int kn = pow(k, n), kn_1 = pow(k, n-1), num[kn_1];fill(num, num + kn_1, k-1);string s(kn + (n-1), '0');for(int i = n-1, node = 0; i < s.size(); ++i) {s[i] = num[node]-- + '0';node = node*k - (s[i-(n-1)]-'0')*kn_1 + num[node] + 1;}return s;}
};

http://www.dtcms.com/wzjs/291370.html

相关文章:

  • 国外旅游哪几个网站做攻略好营销软文范例大全300
  • 网站开发的技术分类直通车关键词怎么选 选几个
  • 做微信的微网站谷歌google play下载
  • 个人备案网站名称怎么写惠州seo整站优化
  • 做商城网站如何寻找货源新闻危机公关
  • 公司建设网站成果预测网络营销出来做什么
  • 凯里网站建设哪家专业超能搜索引擎系统网站
  • 浙江大数据网站建设问答知识百度入口网站
  • 企业网站的域名是该企业的什么百度推广投诉电话客服24小时
  • wordpress照相馆主题广东的seo产品推广服务公司
  • 做一个网站多少费用成都网站seo技巧
  • 必须在当地网站备案如何建立企业网站
  • 淄博圻谷网站建设制作网站外链工具
  • 镇江房地产网站建设自己建网页
  • wordpress文章列表缩略图seo月薪
  • 国外炫酷网站欣赏中国新闻社
  • 免手机微网站域名状态查询工具
  • 淘宝上做网站可信吗推广app网站
  • 自己做的网站怎么样把里面的内容下载下来如何做电商新手入门
  • 如何加强高校网站建设最近新闻内容
  • 福鼎手机网站建设地推的方法和技巧
  • 先做产品网站还是app必应搜索引擎入口官网
  • 门户网站宣传方案十大app开发公司排名
  • 南通网站建设制作狼雨seo网站
  • 专业房地产网站建设深圳网站设计小程序
  • 网站域名重定向怎么做seo教学
  • 做网站ui网络营销论文毕业论文
  • 在线支付 网站模板竞价运营是做什么的
  • 网文网站开发方案适合发表个人文章的平台
  • 我国档案网站建设研究论文软文营销实施背景