检查任意字符串的左移和右移是否会得到给定的字符串

检查任意字符串的左移和右移是否会得到给定的字符串

字符的集合由字符串数据类型表示。它使用字母、数字、符号和空格进行逻辑排列。大多数计算机语言使用单引号或双引号将字符串括起来,以区分它们与其他数据类型。

程序员经常使用字符串来进行一些输入和输出操作,存储和操作文本数据等。字符串的一些常见操作包括拼接(将两个或多个字符串合并)、提取子字符串(获取字符串的一部分)以及在字符串中搜索特定字符或模式。

方法

我们可以使用以下方法来确定字符串的左移右移结果是否为每个字符串−

方法1. 暴力破解法 −

方法2. 检查子字符串 −

方法1:暴力破解法

使用暴力法,生成输入字符串的所有左移和右移,并将每个字符串与目标字符串进行比较。该方法的时间复杂度,其中n是字符串的长度,为O(n2)。

语法

遍历原始字符串的所有可能的左移和右移,并将它们与给定的字符串进行比较,这是确定任何字符串的左移和右移是否会得到给定字符串的蛮力方法。这种策略的一般语法如下所示−

string_shift_check (original_string, given_string):   n = length of original string   for int i from 0 to n-1:      left shift = original string[i:n] + original string[0:i]      right shift = original string[n-i:n] + original string[0:n-i]      if left shift == given string or right shift == given string:         return True   return False

算法

确定一个字符串的左右移是否得到了给定的字符串的蛮力方法是测试字符串的每一个可能的移位,并确定是否有任何一个移位适合给定的字符串。算法如下−

步骤 1 − 开始时将一个变量初始化为0,表示当前的移位计数。

第二步 – 当移位数小于字符串长度时 –

将字符串左移,将第一个字符移到字符串的末尾。

验证移位后的字符串是否与提供的字符串匹配。如果匹配,则给出真实答案。

通过将最后一个字符移到开头,对字符串进行右移。

验证移位后的字符串与提供的字符串是否匹配。如果匹配,给出真答案。

将移位计数增加1。

第三步 – 在尝试了每个可能的移位后,如果没有找到匹配,则返回false。

Example 1

的中文翻译为:

示例 1

这个实现说明函数Shifted String接收两个字符串参数s和target,并返回一个布尔值结果,指示target是s的左移还是右移。

在确定目标是否是s的移位版本之前,函数首先确认两个字符串的长度是否相等。之后,它通过组合每个可能的移位位置之前和之后的子字符串来构建新的字符串。如果左移或右移的字符串在所需字符串中相似,则该方法返回true。如果不是这种情况,则返回false。

在主函数中,我们定义了两个示例字符串s和target,并利用这些字符串调用了Shifted String方法。程序然后指示target是否是s的移位形式。

#include #include using namespace std;bool isShiftedString(string s, string target) {   if(s.length() != target.length()) {      return false;   }   int n = s.length();   for(int i = 0; i < n; i++) {      string leftShift = s.substr(i) + s.substr(0, i); // left shift the string      string rightShift = s.substr(n-i) + s.substr(0, n-i); // right shift the string      if(leftShift == target || rightShift == target) {         return true;      }   }   return false;}int main() {   string s = "abcde";   string target = "cdeab";   if(isShiftedString(s, target)) {      cout << "The string is shifted." << endl;   } else {      cout << "The string is not shifted." << endl;   }   return 0;}

输出

The string is shifted.

方法二:检查子字符串

要确定较小的字符串是否是较长字符串的一部分,可以采用“检查子字符串”的方法。这个过程涉及将与较小字符串相同长度的各个子字符串与较小字符串本身进行比较,同时遍历较长字符串。如果两个字符串匹配,这就确认了较短的字符串确实是较大文本的一个子集。为了增加这篇文章的复杂性和句子长度的变化,这个想法应该被分解成简单而又引人入胜的部分。

语法

以下语法可用于确定任何字符串的左移和右移是否导致提供的字符串 –

if (string_to_check_in.find(substring_to_check) != -1):   //Substring found in string, so it is a left or right shiftelse:   //Substring not found, so it is not a left or right shift

算法

以下算法用于确定字符串的左移和右移是否产生所提供的字符串 −

步骤 1 – 开始输入输入字符串和目标字符串。

第2步 – 验证输入字符串的长度和目标字符串的长度是否相等。如果不相等,则返回False。

步骤3 − 要构建一个新的序列,输入字符串必须与输出字符串合并。

第四步 – 需要进行比较,以确认输入字符串是否包含在新构建的序列中。

步骤 5 – 如果两个字符串完全相同,则答案将是不容置疑的;相反,答案将是否定的。

Example 2

的中文翻译为:

示例2

这是一个C++代码,用于判断左移和右移任意字符串是否会产生给定的字符串 –

此示例研究了两个数组s1和s2之间的连接,以观察它们是否共享任何相似的字符串。通过坚持s1和s2的长度需要相同的前提,它们被合并为一个名为”s1s1″的数组。进一步对该数组进行分析,以确定是否可以找到s2的一部分,搜索的结果将输出”true”或”false”。这种技术提供了对关联的基本反应,用于进一步评估s1和s2的左右字段,以确认两个数组之间的关联。

#include #include using namespace std;bool checkForSubstring(string s1, string s2) {   if (s1.length() != s2.length()) {      return false;   }       string s1s1 = s1 + s1;       if (s1s1.find(s2) != string::npos) {      return true;   }       return false;}int main() {   string s1 = "abcd";   string s2 = "cdab";       if (checkForSubstring(s1, s2)) {      cout << "Yes, left or right shift of string " << s1 << " results in " << s2 << endl;   } else {      cout << "No, left or right shift of string " << s1 << " does not result in " << s2 << endl;   }   return 0;}

输出

Yes, left or right shift of string abcd results in cdab

结论

我们得到了一个字符串用于这个主题,我们需要确定这个字符串是否可以通过反复应用左移和右移来生成。

将提供的字符串与自身连接起来,并确定新字符串是否保留了原始字符串,这样可以解决这个问题。如果是的话,对字符串本身执行左移和右移操作将得到原始字符串。

作为一种替代方案,我们可以遍历每个移位位置,看看是否有任何移位后的字符串与输入字符串匹配。

解决方案的时间复杂度在这两种情况下都是O(n2),其中n是字符串的长度。ft和任何字符串的右移都会导致给定的字符串−

以上就是检查任意字符串的左移和右移是否会得到给定的字符串的详细内容,更多请关注创想鸟其它相关文章!

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

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

相关推荐

  • css怎么把东西往右移

    右移的方法:1、使用margin-left实现div右移,只需要给后一个盒子设置“margin-left:数值”样式即可;2、使用margin-right实现div右移,只需要给前一个盒子设置“margin-right:数值”样式即可。 本教程操作环境:windows7系统、CSS3&&am…

    2025年12月24日 好文分享
    000
  • 如何使用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
  • 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

发表回复

登录后才能评论
关注微信