将字符串A所需附加的最小子序列以获得字符串B

将字符串a所需附加的最小子序列以获得字符串b

在这个问题中,我们需要使用str1的子序列来构造str2。为了解决这个问题,我们可以找到str1的子序列,使其能够覆盖最大长度为str2的子串。在这里,我们将学习两种不同的方法来解决问题。

问题陈述 – 我们给出了两个不同长度的字符串:str1 和 str2。我们需要按照以下条件从 str1 构造 str2。

从 str1 中选取任何子序列,并将其附加到新字符串(最初为空)。

我们需要返回构造str2所需的最少操作数,如果无法构造str2,则打印-1。

示例

输入– str1 =“acd”,str2 =“adc”

输出– 2

说明

str1 中的第一个子序列是“ad”。所以,我们的字符串可以是“ad”。

之后,我们可以从 str1 中获取“c”子序列并将其附加到“ad”以使其成为“adc”。

输入– str1 = “adcb”, str2 = “abdca”

输出– 3

说明

第一个子序列是 str1 中的“ab”。

之后,我们可以获取“dc”字符串,结果字符串将是“abdc”

接下来,我们可以使用“a”子序列来生成最终的字符串“abdca”。

方法 1

在这种方法中,我们将迭代 str1 以查找多个子序列并将其附加到结果字符串中。

算法

定义长度为 26 的“arr”数组,并将所有元素初始化为 0,以存储字符在 str1 中的存在。

迭代str1,根据字符的ASCII值更新数组元素的值

定义“last”变量并使用 -1 进行初始化以跟踪最后访问的元素。另外,定义“cnt”变量并将其初始化为 0 以存储操作计数。

开始使用循环遍历 str2。

如果当前字符不在str1中,则返回-1。

使用“last + 1”值初始化“j”变量。

使用while循环进行迭代,直到j的值小于len,且str1[j]不等于字符

如果‘j’的值大于‘len’,我们遍历‘str1’。增加 ‘cnt’ 变量的值,将 ‘last’ 初始化为 -1,因为我们需要再次遍历 ‘str1’,将 ‘I’ 的值减少 1,因为我们需要再次考虑当前字符,使用 ‘ continue’ 关键字继续迭代。

将“last”变量的值更新为“j”。

循环的所有迭代完成后返回“cnt + 1”。这里,我们需要将“cnt”添加“1”,因为我们不考虑最后一个操作。

示例

#include using namespace std;// function to count the minimum number of operations required to get string str2 from subsequences of string str1.int minOperations(string str1, string str2){   int len = str1.length();   // creating an array of size 26 to store the presence of characters in string str1.   int arr[26] = {0};   // storing the presence of characters in string str1.   for (int i = 0; i < len; i++){      arr[str1[i] - 'a']++;   }   // store the last iterated index of string str1.   int last = -1;   //  to store the count of operations.   int cnt = 0;   for (int i = 0; i < str2.length(); i++){      char ch = str2[i];      // if the character is not present in string str1, then return -1.      if (arr[ch - 'a'] == 0){         return -1;      }      // start iterating from the jth index of string str1 to find the character ch.      int j = last + 1;      while (j = len){         cnt++;         last = -1;         --i;         continue;      }      // set last to j.      last = j;   }   // return cnt + 1 as we haven't counted the last operation.   return cnt + 1;}int main(){   string str1 = "acd", str2 = "adc";   int operations = minOperations(str1, str2);   cout << "Minimum number of operations required to create string B from the subsequences of the string A is: " << operations << "n";   return 0;}

输出

Minimum number of operations required to create string B from the subsequences of the string A is: 2

时间复杂度 – O(N*M),其中 N 是 str2 的长度,M 是 str1 的长度。

空间复杂度 – O(1),因为我们不使用任何动态空间。

方法2

在这种方法中,我们将使用映射和集合数据结构来提高上述方法的效率。解决问题的逻辑与上面的方法相同。

算法

定义“chars_mp”以将 char -> 集{}存储为键值对。

在映射中,存储 str1 字符串中存在特定字符的索引集

定义“last”和“cnt”变量

开始遍历str2。如果包含当前字符索引的集合的大小为零,则返回 -1。

查找当前字符索引集中“last”的上限。

如果找不到上限,请将“cnt”的值增加 1,将“last”设置为 -1,将“I”的值减少 1,然后使用 continue 关键字。 p>

更新“last”变量的值。

循环迭代完成后,返回‘cnt’变量的值

示例

#include #include  #include using namespace std;// function to count the minimum number of operations required to get string str2 from subsequences of string str1.int minOperations(string str1, string str2){   // Length of string str1   int len = str1.length();   // creating the map to store the set of indices for each character in str1   map<char, set> chars_mp;   // Iterate over the characters of str1 and store the indices of each character in the map   for (int i = 0; i < len; i++){      chars_mp[str1[i]].insert(i);   }   // store the last visited index of str1   int last = -1;   // Stores the required count   int cnt = 1;   // Iterate over the characters of str2   for (int i = 0; i < str2.length(); i++){      char ch = str2[i];      // If the set of indices of str2[i] is empty, then return -1      if (chars_mp[ch].size() == 0){         return -1;      }      // If the set of indices of str2[i] is not empty, then find the upper bound of last in the set of indices of str2[i]      // It finds the smallest index of str2[i] which is greater than last      auto it = chars_mp[ch].upper_bound(last);      // If the upper bound is equal to the end of the set, then increment the count and update last to -1       if (it == chars_mp[ch].end()){          last = -1;          cnt++;          // Decrement I by 1 to process the current character again          --i;          continue;      }      // Update last to the current index      last = *it;   }   return cnt;}int main(){   string str1 = "adcb", str2 = "abdca";   int operations = minOperations(str1, str2);   cout << "Minimum number of operations required to create string B from the subsequences of the string A is: " << operations << "n";   return 0;}

输出

Minimum number of operations required to create string B from the subsequences of the string A is: 3

时间复杂度 – O(N*logN),因为我们遍历 str2 并找到循环中“最后一个”索引的上限。

空间复杂度 – O(N),因为我们使用映射来存储字符索引。

以上就是将字符串A所需附加的最小子序列以获得字符串B的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1444858.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 21:57:18
下一篇 2025年12月17日 21:57:22

相关推荐

  • 如何使用JavaScript在不同HTML页面间传递CSS样式值

    本文详细探讨了如何在不同html页面之间传递并持久化css样式值,以实现ui状态的同步。文章首先分析了直接存储dom元素对象导致的问题,随后提出了使用javascript和`localstorage`存储和检索css属性值或样式类名的有效方法。通过提供清晰的代码示例和最佳实践,本教程旨在帮助开发者理…

    2025年12月23日
    000
  • PHP 多语言网站切换:会话管理与翻译函数实践

    本教程详细介绍了使用 php 构建多语言网站的实现方法。文章涵盖了如何通过 url 参数和会话管理实现语言切换,以及如何设计一套健壮的翻译加载与显示机制,以避免常见的变量未定义和字符串偏移错误。通过封装的辅助函数,确保翻译内容正确加载和渲染,提升代码的可维护性和用户体验。 构建多语言网站的核心挑战 …

    2025年12月23日
    300
  • 使用JavaScript和Fetch API动态渲染新闻列表:解决内容覆盖问题

    本教程详细讲解如何利用javascript的fetch api从restful接口获取数据,并动态生成html内容以在网页上展示新闻标题列表。文章将深入探讨在处理数组数据时,如何避免在循环中错误地覆盖dom内容,确保所有数据项都能被正确渲染,从而解决api数据动态渲染时常见的只显示最后一项的问题。 …

    2025年12月23日 好文分享
    000
  • 如何删除html节点_HTML DOM节点删除(removeChild)与内存释放方法

    删除HTML节点的核心方法是removeChild,需通过父节点移除子节点,如parentNode.removeChild(childNode)。现代浏览器也支持更便捷的element.remove()方法,允许节点直接删除自身。节点被移除后虽脱离DOM树,但若JavaScript仍持有其引用(如事…

    2025年12月23日
    100
  • 动态加载图片到Swiper轮播图的正确姿势

    本文详细介绍了如何使用javascript动态加载图片数据并正确填充到swiper轮播图的每个幻灯片中。通过分析常见的错误,如误用`queryselector`和不当的dom操作,教程演示了如何利用`queryselectorall`和适当的迭代方法,确保每张图片都能准确地显示在对应的轮播幻灯片中,…

    好文分享 2025年12月23日
    000
  • R语言:从HTML页面高效提取并解析内嵌JSON数据

    本教程详细介绍了在R语言中如何从包含JSON数据的HTML网页中提取并解析所需信息。针对rvest无法直接解析内嵌JSON的问题,我们将展示如何利用html_text()获取网页的原始文本内容,再结合jsonlite::parse_json()将其转换为R数据结构,并进一步处理以提取特定嵌套字段,最…

    2025年12月22日
    000
  • HTML表格排序怎么实现_HTML表格JavaScript排序功能教程

    通过JavaScript实现HTML表格排序,核心是监听表头点击事件,获取列数据后按类型(字符串、数字、日期)进行升序或降序排序,并利用DocumentFragment优化DOM操作以提升性能。 HTML表格排序,说白了就是通过JavaScript来动态调整表格行的顺序。这听起来可能有点复杂,但核心…

    2025年12月22日 好文分享
    000
  • 动态创建HTML输入字段、捕获其值并构建动态字符串的JavaScript教程

    本文详细介绍了如何使用JavaScript动态创建HTML输入字段,高效捕获这些动态字段的用户输入值,并利用这些值灵活构建动态字符串。教程将指导读者避免传统变量命名陷阱,转而采用数组和类选择器等现代方法,确保代码的健壮性和可扩展性。 在现代web应用开发中,经常需要根据用户交互动态地添加或移除表单元…

    2025年12月22日
    000
  • 如何在JavaScript中将字符串转换为小写字母?

    要将 JavaScript 中的字符串转换为小写字母,请使用 toLocaleLowerCase() 方法。 示例 您可以尝试运行以下代码来了解如何在 JavaScript 中使用 toLocaleLowerCase() 方法 – 实时演示 var a = “WELCOME!”; doc…

    2025年12月21日
    000
  • 匹配任何包含零个或多个p的字符串

    要使用 JavaScript RegExp 匹配任何包含零个或多个 p 的字符串,请使用 p* 量词。 示例 您可以尝试运行以下代码来匹配包含零个或多个 p 的任何字符串。这里,p 被认为是出现的次数 – JavaScript Regular Expression var myStr =…

    2025年12月21日
    000
  • 如何将当前语言环境的约定,将日期的“时间”部分作为字符串返回?

    要使用当前语言环境的约定以字符串形式返回日期的“时间”部分,请使用 toLocaleTimeString() 方法。 toLocaleTimeString 方法依赖于格式化日期的底层操作系统。它使用运行脚本的操作系统的格式约定将日期转换为字符串。例如,在美国,月份出现在日期之前 (04/15/98)…

    2025年12月21日
    000
  • JavaScript数组-字符串-数学函数

    这次给大家带来javascript数组-字符串-数学函数,使用javascript数组-字符串-数学函数的注意事项有哪些,下面就是实战案例,一起来看一下。 数组方法里push、pop、shift、unshift、join、split分别是什么作用。push()方法添加一个或多个元素到数组的末尾,并返…

    好文分享 2025年12月21日
    000
  • html规定激活(使元素获得焦点)元素的快捷键的属性accesskey

    实例 带有指定快捷键的超链接: HTMLCSS 浏览器支持 几乎所有浏览器均 accesskey 属性,除了 Opera。 定义和用法 accesskey 属性规定激活(使元素获得焦点)元素的快捷键。 提示和注释 注释:以下元素支持 accesskey 属性:, , , , , 以及 。 语法 属性…

    好文分享 2025年12月21日
    000
  • js中repeat()的使用

    repeat()方法用于将字符串重复指定次数并返回新字符串。例如’Hello’.repeat(3)结果为’HelloHelloHello’;传入小数自动向下取整,负数或无法转换的字符串会报错。 在 JavaScript 中,repeat() 是一个字符…

    2025年12月21日
    000
  • JavaScript输入框数值计算结果的货币格式化显示

    本教程详细介绍了如何利用javascript的`tolocalestring()`方法,将用户输入框中的数值计算结果,如乘积,优雅地格式化为符合特定区域设置的货币形式(例如$9,000),并将其显示在另一个输入框中。文章将涵盖`tolocalestring()`的关键参数及其在实际应用中的配置,帮助…

    2025年12月21日
    000
  • 如何从HTML字符串中高效提取标签的src属性

    <img src="https://img.php.cn/upload/article/001/246/273/175902558447559.jpg" alt="如何从HTML字符串中高效提取标签的src属性”>标签的src属性” …

    好文分享 2025年12月20日
    000
  • js怎么判断字符串是否包含子串

    判断字符串是否包含子串最推荐使用includes(),因其语义清晰且直接返回布尔值;2. 若需获取子串位置或兼容旧浏览器,则选用indexof(),通过返回值是否为-1判断存在性;3. 对于复杂模式匹配或不区分大小写的查找,应使用正则表达式,其中test()方法适合布尔判断,match()可返回匹配…

    2025年12月20日
    000
  • js如何将字符串转换为数组

    在javascript中,将字符串转换为数组的核心方法是使用split()。1. 使用split()可根据指定分隔符将字符串分割成数组,如str.split(“,”)可按逗号分割;2. 当存在连续分隔符时,split()会保留空字符串元素,可通过filter(boolean)…

    2025年12月20日 好文分享
    000
  • javascript如何将数组转为字符串

    javascript中将数组转换为字符串最直接的方法是使用join()或tostring();2. join()方法可自定义分隔符,若不指定则默认使用逗号,而tostring()方法始终使用逗号且不接受参数;3. join()适用于需要控制输出格式的场景,如生成csv、url参数或html内容,to…

    2025年12月20日 好文分享
    000
  • js如何实现字符串截断

    javascript中截断字符串的核心方法有slice()、substring()和substr();2. slice()支持负索引且行为可预测,推荐使用;3. substring()不支持负索引且会自动交换参数顺序,需注意其“智能”行为;4. substr()第二个参数为长度而非结束索引,但已被废…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信