”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > LeetCode 冥想:解码方法

LeetCode 冥想:解码方法

发布于2024-08-01
浏览:317

LeetCode Meditations: Decode Ways

我们先来描述这个问题:

您截获了一条编码为数字字符串的秘密消息。该消息通过以下映射进行解码

“1”->“A”“2”->“B”...“25”->“Y”“26”->“Z”

但是,在解码消息时,您意识到可以通过多种不同的方式解码消息,因为某些代码包含在其他代码中(“2”和“5”与“25”)。

例如“11106”可以解码为:

  • “AAJF”,分组为 (1, 1, 10, 6)
  • “KJF”与分组 (11, 10, 6)
  • 分组 (1, 11, 06) 无效,因为“06”不是有效代码(只有“6”有效)。

注意:可能存在无法解码的字符串。

给定一个仅包含数字的字符串 s,返回对其进行解码的方式数。如果整个字符串无法以任何有效方式解码,则返回 0.

生成测试用例,以便答案适合32位整数。

例如:

Input: s = "12"

Output: 2

Explanation: "12" could be decoded as "AB" (1 2) or "L" (12).

或者:

Input: s = "226"

Output: 3

Explanation: "226" could be decoded as "BZ" (2 26), "VF" (22 6), or "BBF" (2 2 6).

或者:

Input: s = "06"

Output: 0

Explanation: "06" cannot be mapped to "F" because of the leading zero ("6" is different from "06"). In this case, the string is not a valid encoding, so return 0.

约束条件是:

  • 1
  • s 仅包含数字,并且可能包含前导零。

我认为这是您乍一看并不那么困难的问题之一,直到您尝试解决它为止。

首先,让我们从最简单的见解开始:一个字符可以被解码为它本身(仅一个字符)或两位数的一部分。
如果它是第一个选项,我们只能有从 1 到 9 的数字,因为 0 本身不映射到任何东西。
但是,两位数的范围可以是 10 到 26。

与本章前面的问题一样,我们可以首先创建一个 dp 数组来保存迭代字符串时每个字符的解码方式数量。
与爬楼梯非常相似,我们必须使用长度 s.length 1 初始化数组,因为我们需要考虑我们尚未解码任何内容的事实。
换句话说,当没有字符时,只有一种方式来“解码”:根本不解码。

因此,我们可以将所有值初始化为 0,除了第一个索引将是 1。

let dp = Array.from({ length: s.length   1 }, () => 0);

dp[0] = 1;

同样,与前面的问题类似,我们必须保留底部的两个值,因此我们必须初始化数组的第二个槽,它对应于解码字符串中第一个字符的方法数。

我们知道,如果它是“0”,我们就无法对其进行解码,因此在这种情况下解码它的方法数将为 0。
请注意,无法解码根本不进行任何解码不同:在第一种情况下,解码方式的数量为0,但在第二种情况下(如我们刚刚用dp[0]做的),可以说解码的方式数是1。

在所有其他情况下,只有一种方法对其进行解码,因为它只是一个字符。因此,我们将相应地初始化 dp[1]:

dp[1] = (s[0] === '0') ? 0 : 1;

现在我们可以从第三个索引开始迭代。我们将同时查看前一个数字和前两个数字。

只要前一个数字不是数字 0,我们就可以添加数组前一个槽中的任何内容。

并且,只要前两位数字构成10到26之间的数字,我们也可以添加相应的解决方案。总而言之,它可以看起来像这样:

for (let i = 2; i 



笔记
我们使用方便的一元加运算符将字符串字符转换为数字。从问题约束中我们知道字符串 s 只包含数字。

此时,我们在最后一个索引(对应于 s.length)中得到了结果,因此我们可以返回它:

function numDecodings(s: string): number {
  /* ... */

  return dp[s.length]; 
}

总的来说,我们的解决方案是这样的:

function numDecodings(s: string): number {
  let dp = Array.from({ length: s.length   1 }, () => 0);

  dp[0] = 1;
  dp[1] = (s[0] === '0') ? 0 : 1;

  for (let i = 2; i 



时间和空间复杂度

该解决方案的时间和空间复杂度均为 O(n)O(n) 在) 当我们迭代所有字符进行常量操作时,我们必须保留一个数组,其大小将随着输入大小的增加而增加。


接下来是硬币找零的问题。在那之前,祝您编码愉快。

版本声明 本文转载于:https://dev.to/rivea0/leetcode-meditations-decode-ways-6d5?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • JavaScript的伴侣
    JavaScript的伴侣
    [2 了解JavaScript承诺 承诺是JavaScript中的一个强大功能,可以简化处理异步操作的处理。它们提供了一种更清洁,更直观的方式来处理异步代码,避免了诸如“回调地狱”之类的问题。 什么是诺言? 是一个代表异步操作的最终完成(或失败)及其结果值的对象。它使...
    编程 发布于2025-02-06
  • 如何在整个HTML文档中设计特定元素类型的第一个实例?
    如何在整个HTML文档中设计特定元素类型的第一个实例?
    [2单独使用CSS,整个HTML文档可能是一个挑战。 the:第一型伪级仅限于与其父元素中类型的第一个元素匹配。 以下CSS将使用添加的类样式的第一个段落: }
    编程 发布于2025-02-06
  • 如何使用Flexbox将元素与容器的底部对齐?
    如何使用Flexbox将元素与容器的底部对齐?
    在提供的方案中使用FlexBox 在提供的方案中,您有一个带有各种子元素的div容器。您的目的是实现一个布局,而元素垂直堆叠,无论文本的高度如何。 flexbox通过自动保证金提供了解决此问题的解决方案。自动利润率使剩余空间在对齐之前的元素中分布到具有自动边缘的元素。实现所需布局的一种方法是使用以...
    编程 发布于2025-02-06
  • 如何精确测量.NET中的方法执行时间?
    如何精确测量.NET中的方法执行时间?
    .NET方法执行时间的精确计算 引言: 确定方法的执行时间对于性能优化至关重要。有多种方法可以测量此指标,每种方法都有其优点和缺点。 最佳方法:Stopwatch .NET 中的Stopwatch功能专门用于测量执行时间,被认为是最准确和最直接的方法。使用方法如下: var watch = Sys...
    编程 发布于2025-02-06
  • 如何使用char_length()在mySQL中按字符串长度对数据进行排序?
    如何使用char_length()在mySQL中按字符串长度对数据进行排序?
    [2使用内置的char_length()function。 char_length()和length() 此查询将从指定的表中检索所有行,并基于上升顺序对它们进行排序指定列的字符长度。带有更长字符串的行将出现在结果的底部。
    编程 发布于2025-02-06
  • 如何使用Python的记录模块实现自定义处理?
    如何使用Python的记录模块实现自定义处理?
    使用Python的Loggging Module 确保正确处理和登录对于疑虑和维护的稳定性至关重要Python应用程序。尽管手动捕获和记录异常是一种可行的方法,但它可能乏味且容易出错。解决此问题,Python允许您覆盖默认的异常处理机制,并将其重定向为登录模块。这提供了一种方便而系统的方法来捕获和...
    编程 发布于2025-02-06
  • 哪种哈希算法最适合PHP中的安全密码存储?
    哪种哈希算法最适合PHP中的安全密码存储?
    安全密码存储:SHA1 vs MD5 VS SHA256 vs bcrypt bcrypt:首选选择 通过password_hash()函数: //创建哈希 $ hash = password_hash($ password,password_default,['cost'=> ...
    编程 发布于2025-02-06
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-02-06
  • 如何使用shell_exec()从php执行mySQL *.sql文件?
    如何使用shell_exec()从php执行mySQL *.sql文件?
    在PHP 中执行mysql *.sql文件时,在创建网站数据库时,您可能会遇到需要执行的方案。 SQL文件从PHP到自动化站点生成。虽然zend_framework可能是有益的,但由于SQL语句中的不一致而直接运行。推荐的方法是使用Shell_exec()调用MySQL工具以执行您的 *.sql脚...
    编程 发布于2025-02-06
  • 为什么C#没有用于IEnumerable的for Extension方法?
    为什么C#没有用于IEnumerable的for Extension方法?
    [2 [2 最近关于C#缺乏扩展方法的扩展方法] 界面? 有趣的是,只有 list 包括此功能。 [2 这是遗漏的性能优化吗?还是有更深的根本原因? 几种理论试图解释这一明显的差距。 [2 一个观点表明,C#的内置 [2 { item.dosomething(); } 这与扩展方法...
    编程 发布于2025-02-06
  • 对象拟合:IE和Edge中的封面失败,如何修复?
    对象拟合:IE和Edge中的封面失败,如何修复?
    解决此问题,我们采用了一个巧妙的CSS解决方案来解决问题:高度:100%; 高度:auto; 宽度:100%; //对于水平块 ,使用绝对定位将图像定位在中心,以object-fit:object-fit:cover in IE和edge消除了问题。现在,图像将按比例扩展,保持所需的效果而不会失...
    编程 发布于2025-02-06
  • 如何将LINQ的聚合方法用于有效的字符串串联?
    如何将LINQ的聚合方法用于有效的字符串串联?
    与linq 的传统方法涉及使用stringBuilder并在循环中附加每个字符串。但是,对于更有效的方法,LINQ提供了聚合查询。一个汇总查询是一个函数,该函数获取值集合并返回标量值。使用点通用,您可以在iEnumerable对象上调用聚合查询。与LINQ concateNate strings...
    编程 发布于2025-02-06
  • PHP中整数的最大值是多少?
    PHP中整数的最大值是多少?
    在php中揭示了int值的限制:探索php_int_max 在PHP 未签名的整数和php 确定整数大小和最大值 64位平台和int values 在摘要中,而PHP中的特定int值范围取决于平台,典型的最大值大约为通常遇到20亿。在与整数合作以确保准确的计算和有效的代码执行时,了解这些限制至关重...
    编程 发布于2025-02-06
  • 在没有密码提示的情况下,如何在Ubuntu上安装MySQL?
    在没有密码提示的情况下,如何在Ubuntu上安装MySQL?
    在ubuntu 使用debconf-set-selections sudo debconf-set-selections
    编程 发布于2025-02-06
  • 如何在Python中生成具有小数步骤值的范围?
    如何在Python中生成具有小数步骤值的范围?
    在range()要克服此限制,建议将步骤值指定为在范围内生成的点数。 Numpy库提供了linspace函数,该功能需要多个点和可选的终点值。例如: np.linspace(0,1,10,endpoint = false)#返回[0,0.1,0.2,...,0.9] 如果使用浮点数步骤值,则Num...
    编程 发布于2025-02-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3