\\\"Leetcode:

时间和空间复杂度

时间复杂度: 在最坏的情况下,我们迭代 Min(str1,str2) 并且需要重新创建 str1 和 str2,这样整体时间复杂度将是 (str1.length str2.length)将是 O(min(str1,str2) * (str1.length str2.length))

空间复杂度: O(1),因为我们不需要任何额外的空间。

","image":"http://www.luping.net/uploads/20241012/1728725766670a43065f5b5.jpg","datePublished":"2024-11-07T22:30:30+08:00","dateModified":"2024-11-07T22:30:30+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Leetcode:字符串的最大公约数

Leetcode:字符串的最大公约数

发布于2024-11-07
浏览:530

问题陈述 1071. 字符串的最大公约数

对于两个字符串 s 和 t,当且仅当 s = t t t ... t t (即 t 与自身连接一次或多次)时,我们才说“t 除 s”。

给定两个字符串 str1 和 str2,返回使 x 整除 str1 和 str2 的最大字符串 x。

我的思考过程

尽管leetcode将其标记为简单问题,但我必须承认我发现很难立即想出解决方案。

让我回顾一下 leetcode 提供的测试用例并仔细检查它们以解释我的困惑。

测试用例

输入:str1 = "ABCABC", str2 = "ABC"
输出:“ABC”

输入:str1 = "ABABAB", str2 = "ABAB"
输出:“AB”

从问题陈述和测试用例 1 中,我确实确定我们需要输出最大的字符串(“ABC”),连接起来我们可以得到两个字符串。 (默认字符串“ABC”=== str2 和“ABC”“ABC”=== str1)。

然而,查看测试用例 2,我很快意识到我的理解不正确,因为我应该输出“ABAB”,因为这是我可以创建两个字符串的最长字符串。但我开始编写代码并开始制定解决方案。 (菜鸟错误?)

失败/成功的事情

我只能制定出一个解决方案:

  1. 求两个字符串的GCD。
  2. 从最小字符串的长度迭代到GCD
  3. 从最小字符串到当前迭代值取一个子串。
  4. 如果两个字符串都包含该子字符串,则返回该子字符串作为答案。
  5. 如果没有找到字符串,则返回“”。

正如您所看到的,对于 str1 包含 str2 但还包含一些其他附加字符的字符串,我的解决方案失败了。违反了 s = t t ... t t.

的要求

我不得不向neetcode的解决方案寻求帮助。我很快就明白了我的问题:

  1. 我正在寻找字符串长度的 GCD,而不是字符串本身。我需要找到一个字符串,重复这些字符串我可以创建两个字符串而没有任何剩余字符。

  2. 我意识到为什么“ABAB”不能成为测试用例2的答案:

  • 我们需要找到 x 以便将两个字符串均分。因此,以“ABAB”作为字符串,您可以完全创建 str2,但对于 str1,您最终会得到“ABABABAB”。你最终会得到 2 个多余的“AB”,并且不能说你完全通过组合 x.

  • 创建了 str1
  • “ABAB”长度为 4 且“ABABAB”长度为 6。2 个字符串的 GCD = 2。因此输出需要是长度为 2 的字符串。

输出

Leetcode: Greatest Common Divisor of Strings

时间和空间复杂度

时间复杂度: 在最坏的情况下,我们迭代 Min(str1,str2) 并且需要重新创建 str1 和 str2,这样整体时间复杂度将是 (str1.length str2.length)将是 O(min(str1,str2) * (str1.length str2.length))

空间复杂度: O(1),因为我们不需要任何额外的空间。

版本声明 本文转载于:https://dev.to/decoders_lord/leetcode-1071-greatest-common-divisor-of-strings-4dcc?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • Go语言如何动态发现导出包类型?
    Go语言如何动态发现导出包类型?
    与反射软件包中的有限类型的发现能力相反,本文探索了替代方法,探索了在Runruntime。go import( “ FMT” “去/进口商” ) func main(){ pkg,err:= incorter.default()。导入(“ time”) 如果err...
    编程 发布于2025-07-13
  • 如何使用“ JSON”软件包解析JSON阵列?
    如何使用“ JSON”软件包解析JSON阵列?
    parsing JSON与JSON软件包 QUALDALS:考虑以下go代码:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
    编程 发布于2025-07-13
  • 如何处理PHP文件系统功能中的UTF-8文件名?
    如何处理PHP文件系统功能中的UTF-8文件名?
    在PHP的Filesystem functions中处理UTF-8 FileNames 在使用PHP的MKDIR函数中含有UTF-8字符的文件很多flusf-8字符时,您可能会在Windows Explorer中遇到comploreer grounder grounder grounder gro...
    编程 发布于2025-07-13
  • 如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    Red: How to Redirect Multiple User Types to Respective ActivitiesUnderstanding the ProblemIn a Firebase-based voting app with three distinct user type...
    编程 发布于2025-07-13
  • 哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    在Python Matplotlib's path.contains_points FunctionMatplotlib's path.contains_points function employs a path object to represent the polygon.它...
    编程 发布于2025-07-13
  • C++成员函数指针正确传递方法
    C++成员函数指针正确传递方法
    如何将成员函数置于c [&& && && && && && && && && && &&&&&&&&&&&&&&&&&&&&&&&华仪的函数时,在接受成员函数指针的函数时,要在函数上既要提供指针又可以提供指针和指针到函数的函数。需要具有一定签名的功能指针。要通过成员函数,您需要同时提供对象指针(此...
    编程 发布于2025-07-13
  • 如何简化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-13
  • 如何避免Go语言切片时的内存泄漏?
    如何避免Go语言切片时的内存泄漏?
    ,a [j:] ...虽然通常有效,但如果使用指针,可能会导致内存泄漏。这是因为原始的备份阵列保持完整,这意味着新切片外部指针引用的任何对象仍然可能占据内存。 copy(a [i:] 对于k,n:= len(a)-j i,len(a); k
    编程 发布于2025-07-13
  • 您如何在Laravel Blade模板中定义变量?
    您如何在Laravel Blade模板中定义变量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配变量对于存储以后使用的数据至关重要。在使用“ {{}}”分配变量的同时,它可能并不总是最优雅的解决方案。幸运的是,Blade通过@php Directive提供了更优雅的方法: $ old_section =“...
    编程 发布于2025-07-13
  • 如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    postgresql:为每个唯一标识符提取最后一行,在Postgresql中,您可能需要遇到与在数据库中的每个不同标识相关的信息中提取信息的情况。考虑以下数据:[ 1 2014-02-01 kjkj 在数据集中的每个唯一ID中检索最后一行的信息,您可以在操作员上使用Postgres的有效效率: ...
    编程 发布于2025-07-13
  • 如何从Google API中检索最新的jQuery库?
    如何从Google API中检索最新的jQuery库?
    从Google APIS 问题中提供的jQuery URL是版本1.2.6。对于检索最新版本,以前有一种使用特定版本编号的替代方法,它是使用以下语法:获取最新版本:未压缩)While these legacy URLs still remain in use, it is recommended ...
    编程 发布于2025-07-13
  • 如何使用Python理解有效地创建字典?
    如何使用Python理解有效地创建字典?
    在python中,词典综合提供了一种生成新词典的简洁方法。尽管它们与列表综合相似,但存在一些显着差异。与问题所暗示的不同,您无法为钥匙创建字典理解。您必须明确指定键和值。 For example:d = {n: n**2 for n in range(5)}This creates a dicti...
    编程 发布于2025-07-13
  • 如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    How to Resolve "General error: 2006 MySQL server has gone away" While Inserting RecordsIntroduction:Inserting data into a MySQL database can...
    编程 发布于2025-07-13
  • 如何有效地转换PHP中的时区?
    如何有效地转换PHP中的时区?
    在PHP 利用dateTime对象和functions DateTime对象及其相应的功能别名为时区转换提供方便的方法。例如: //定义用户的时区 date_default_timezone_set('欧洲/伦敦'); //创建DateTime对象 $ dateTime = ne...
    编程 发布于2025-07-13
  • 如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    为有效的slug生成首先,该函数用指定的分隔符替换所有非字母或数字字符。此步骤可确保slug遵守URL惯例。随后,它采用ICONV函数将文本简化为us-ascii兼容格式,从而允许更广泛的字符集合兼容性。接下来,该函数使用正则表达式删除了不需要的字符,例如特殊字符和空格。此步骤可确保slug仅包含...
    编程 发布于2025-07-13

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

Copyright© 2022 湘ICP备2022001581号-3