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

LeetCode 冥想:解码方法

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

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]删除
最新教程 更多>
  • 表单刷新后如何防止重复提交?
    表单刷新后如何防止重复提交?
    在Web开发中预防重复提交 在表格提交后刷新页面时,遇到重复提交的问题是常见的。要解决这个问题,请考虑以下方法: 想象一下具有这样的代码段,看起来像这样的代码段:)){ //数据库操作... 回声“操作完成”; 死(); } ?> ...
    编程 发布于2025-07-03
  • 左连接为何在右表WHERE子句过滤时像内连接?
    左连接为何在右表WHERE子句过滤时像内连接?
    左JOIN CONUNDRUM:WITCHING小时在数据库Wizard的领域中变成内在的加入很有趣,当将c.foobar条件放置在上面的Where子句中时,据说左联接似乎会转换为内部连接。仅当满足A.Foo和C.Foobar标准时,才会返回结果。为什么要变形?关键在于其中的子句。当左联接的右侧值...
    编程 发布于2025-07-03
  • 图片在Chrome中为何仍有边框?`border: none;`无效解决方案
    图片在Chrome中为何仍有边框?`border: none;`无效解决方案
    在chrome 在使用Chrome and IE9中的图像时遇到的一个频繁的问题是围绕图像的持续薄薄边框,尽管指定了图像,尽管指定了;和“边境:无;”在CSS中。要解决此问题,请考虑以下方法: Chrome具有忽略“ border:none; none;”的已知错误,风格。要解决此问题,请使用以下...
    编程 发布于2025-07-03
  • 如何在鼠标单击时编程选择DIV中的所有文本?
    如何在鼠标单击时编程选择DIV中的所有文本?
    在鼠标上选择div文本单击带有文本内容,用户如何使用单个鼠标单击单击div中的整个文本?这允许用户轻松拖放所选的文本或直接复制它。 在单个鼠标上单击的div元素中选择文本,您可以使用以下Javascript函数: function selecttext(canduterid){ if(do...
    编程 发布于2025-07-03
  • 在JavaScript中如何并发运行异步操作并正确处理错误?
    在JavaScript中如何并发运行异步操作并正确处理错误?
    同意操作execution 在执行asynchronous操作时,相关的代码段落会遇到一个问题,当执行asynchronous操作:此实现在启动下一个操作之前依次等待每个操作的完成。要启用并发执行,需要进行修改的方法。 第一个解决方案试图通过获得每个操作的承诺来解决此问题,然后单独等待它们: co...
    编程 发布于2025-07-03
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-07-03
  • Java的Map.Entry和SimpleEntry如何简化键值对管理?
    Java的Map.Entry和SimpleEntry如何简化键值对管理?
    A Comprehensive Collection for Value Pairs: Introducing Java's Map.Entry and SimpleEntryIn Java, when defining a collection where each element com...
    编程 发布于2025-07-03
  • 人脸检测失败原因及解决方案:Error -215
    人脸检测失败原因及解决方案:Error -215
    错误处理:解决“ error:((-215)!empty()in Function Multultiscale中的“ openCV 要解决此问题,必须确保提供给HAAR CASCADE XML文件的路径有效。在提供的代码片段中,级联分类器装有硬编码路径,这可能对您的系统不准确。相反,OPENCV提...
    编程 发布于2025-07-03
  • 如何使用Python理解有效地创建字典?
    如何使用Python理解有效地创建字典?
    在python中,词典综合提供了一种生成新词典的简洁方法。尽管它们与列表综合相似,但存在一些显着差异。与问题所暗示的不同,您无法为钥匙创建字典理解。您必须明确指定键和值。 For example:d = {n: n**2 for n in range(5)}This creates a dicti...
    编程 发布于2025-07-03
  • 在C#中如何高效重复字符串字符用于缩进?
    在C#中如何高效重复字符串字符用于缩进?
    在基于项目的深度下固定字符串时,重复一个字符串以进行凹痕,很方便有效地有一种有效的方法来返回字符串重复指定的次数的字符串。使用指定的次数。 constructor 这将返回字符串“ -----”。 字符串凹痕= new String(' - ',depth); console.Wr...
    编程 发布于2025-07-03
  • 如何简化PHP中的JSON解析以获取多维阵列?
    如何简化PHP中的JSON解析以获取多维阵列?
    php 试图在PHP中解析JSON数据的JSON可能具有挑战性,尤其是在处理多维数组时。 To simplify the process, it's recommended to parse the JSON as an array rather than an object.To do...
    编程 发布于2025-07-03
  • Java数组中元素位置查找技巧
    Java数组中元素位置查找技巧
    在Java数组中检索元素的位置 利用Java的反射API将数组转换为列表中,允许您使用indexof方法。 (primitives)(链接到Mishax的解决方案) 用于排序阵列的数组此方法此方法返回元素的索引,如果发现了元素的索引,或一个负值,指示应放置元素的插入点。
    编程 发布于2025-07-03
  • Python高效去除文本中HTML标签方法
    Python高效去除文本中HTML标签方法
    在Python中剥离HTML标签,以获取原始的文本表示Achieving Text-Only Extraction with Python's MLStripperTo streamline the stripping process, the Python standard librar...
    编程 发布于2025-07-03
  • Go web应用何时关闭数据库连接?
    Go web应用何时关闭数据库连接?
    在GO Web Applications中管理数据库连接很少,考虑以下简化的web应用程序代码:出现的问题:何时应在DB连接上调用Close()方法?,该特定方案将自动关闭程序时,该程序将在EXITS EXITS EXITS出现时自动关闭。但是,其他考虑因素可能保证手动处理。选项1:隐式关闭终止数...
    编程 发布于2025-07-03
  • 用户本地时间格式及时区偏移显示指南
    用户本地时间格式及时区偏移显示指南
    在用户的语言环境格式中显示日期/时间,并使用时间偏移在向最终用户展示日期和时间时,以其localzone and格式显示它们至关重要。这确保了不同地理位置的清晰度和无缝用户体验。以下是使用JavaScript实现此目的的方法。方法:推荐方法是处理客户端的Javascript中的日期/时间格式化和时...
    编程 发布于2025-07-03

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

Copyright© 2022 湘ICP备2022001581号-3