C++程序:找到具有相同左右旋转的数字的最长子序列

c++程序:找到具有相同左右旋转的数字的最长子序列

在这个问题中,我们需要找到左右旋转相同的子序列的最大长度。左旋转是指将字符串中的所有字符向左移动,并将末尾的第一个字符移动。右旋转意味着将所有字符串字符向右移动,并将最后一个字符移动到开头。

问题陈述 – 我们给定了包含数字的字符串str,需要找到左右旋转相同的最大长度的子序列。

示例

输入-str =“323232”,

输出– 6

立即学习“C++免费学习笔记(深入)”;

解释 – 左右旋转相同的最长子序列是“323232”。左旋转为‘232323’,右旋转为‘232323’。

输入-str = ‘00010100’

输出– 6

立即学习“C++免费学习笔记(深入)”;

说明 – 左右旋转相同的最长子序列是“000000”。

输入-str = ‘092312110431010’

输出– 6

立即学习“C++免费学习笔记(深入)”;

解释 – 有 2 个可能的长度为 6 且左右旋转相同的子序列。第一个是“010101”,第二个是“101010”。

方法 1

在这种方法中,我们将找到给定字符串的所有可能的子序列。之后,我们将检查字符串的左右旋转是否相同。我们将使用递归方法来查找所有可能的子序列。

算法

将“maxLen”全局变量初始化为零,以存储左右旋转相同的最长子序列的长度。

定义 isRightSameLeft() 函数来检查字符串左右旋转是否相同。

在函数内部,使用 substr() 方法左右旋转字符串。

getAllSubSeq() 函数用于查找给定字符串的所有可能的子序列。

定义基本情况。如果str为空,我们获取子序列并执行isRightSameLeft()函数来检查子序列是否具有相同的左右旋转。如果是,如果“maxLen”变量的长度大于“maxLen”的当前值,则更新“maxLen”变量的值。

从“str”中删除第一个字符并附加“out”字符串后进行递归调用。

删除第一个字符并保持“out”字符串不变后,再次进行递归函数调用。在此递归调用中,我们排除“str”的第一个字符。

示例

#include #include using namespace std;// Defining global variable to store the length of the longest subsequence according to the given conditionint maxLen = 0;//  function to check if the string is the same after the left rotationbool isRightSameLeft(string str) {   int len = str.length();   return str.substr(1, len - 1) + str[0] == str[len - 1] + str.substr(0, len - 1);}// function to get all subsequences of a stringvoid getAllSubSeqs(string str, string out) {   // If the string is empty, we get the subsequences. Check if its left and right rotation is the same   if (str.empty()) {      if (isRightSameLeft(out))          maxLen = max(maxLen, (int)out.length());      return;   }   // Recursive case remove the first character from str, and add it to the output   getAllSubSeqs(str.substr(1), out + str[0]);   // remove the first character from str, and drop it   if (str.length() > 1)      getAllSubSeqs(str.substr(1), out);}int main() {   string str = "323232";   string out = "";   getAllSubSeqs(str, out);   cout << "The longest subsequence of str having same left and right rotation is " << maxLen;   return 0;}

输出

The longest subsequence of str having same left and right rotation is 6

时间复杂度 – O(N*2N)。这里 O(N) 用于比较左右旋转,O(2N) 用于查找所有可能的子序列。

空间复杂度 – O(1),因为我们不使用额外的空间。

方法2

这里,我们对上面的方法进行了优化。我们可以观察样本输入的解决方案。仅当子序列包含相同字符或交替包含两个不同字符且长度为偶数时,子序列的左右旋转才相同。

算法

使用两个嵌套循环来组合任意两个数字。

定义‘cnt’变量来查找交替包含两个数字的子序列的长度,并初始化为零。

定义布尔类型的“first”变量来跟踪下一个字符应该是第i个还是第j个。

使用循环遍历字符串。

如果first == true且str[k] – ‘0’ == I,则交替’first’的值并将’cnt’增加1。

如果first == false且str[k] – ‘0’== j,则再次交替’first’的值并将’cnt’增加1。

如果 i 和 j 不相等,且“cnt”值为奇数,则将其减 1。

如果 cnt 值大于“res”,则更新“res”变量的值。

示例

#include using namespace std;int getLongSubSeq(string str) {   // Store the length of the string   int len = str.size(), res = 0;   // Traverse the all possible combination of two digits   for (int i = 0; i < 10; i++) {      for (int j = 0; j < 10; j++) {          // to store the length of an alternating sequence of the current combination          int cnt = 0;          // to track the turn of the ith or jth digit          bool first = true;          // traverse the string          for (int k = 0; k < len; k++) {              // If the current digit is equal to I, and the first is true, increment the count              if (first == true and str[k] - '0' == i) {                  first = false;                  cnt++;              } else if (first == false and str[k] - '0' == j) {                  // If the current digit is equal to j, and the first is false, increment the count                  first = true;                  cnt++;              }          }          // If the sequence is odd and i and j are different, decrement the count          if (i != j and cnt % 2 == 1)              cnt--;          // Update the answer          res = max(cnt, res);       }   }   return res;}int main() {   string str = "00010100";   cout << "The longest subsequence of str having same left and right rotation is " << getLongSubSeq(str);   return 0;}

输出

The longest subsequence of str having same left and right rotation is 6

时间复杂度 – O(10*10*N),因为我们从包含数字组合的字符串中找到子序列。

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

本教程教给我们两种方法来查找包含相同左右旋转的最长子序列。第一种方法是简单的方法,这种方法非常耗时,而且我们不能将其用于大量输入。

第二种方法经过优化,其时间复杂度几乎等于 O(N)。

以上就是C++程序:找到具有相同左右旋转的数字的最长子序列的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 21:00:44
下一篇 2025年12月17日 21:01:15

相关推荐

  • 利用CSS实现纯英文数字自动换行

    下面为大家带来一篇css代码使纯英文数字自动换行的简单实现。内容挺不错的,现在就分享给大家,也给大家做个参考。 当一个定义了宽度的块状元素中填充的全部为纯英文或者纯数字的时候,在IE和FF中都会撑大容器,不会自动换行 并且当数字或者英文中带有汉字时,会从汉字处换行,而纯汉字却可以自动换行。这个问题如…

    好文分享 2025年12月24日
    000
  • html5怎么设置input只能输入数字

    在html5中,可以通过input标签的type属性来实现只能输入数字的功能,只需要将type属性的值设置为“number”即可,语法“”。 本教程操作环境:windows7系统、HTML5版、Dell G3电脑。 标签规定用户可输入数据的输入字段。 根据不同的 type 属性,输入字段有多种形态。…

    2025年12月21日
    000
  • HTML怎么实现数字焦点图轮播代码

    html怎么实现数字焦点图轮播代码?数字焦点图轮播怎么做?数字焦点图轮播需要注意什么?给大家一份实现数字焦点图轮播代码,需要的朋友可以借鉴一下。 数字焦点图轮播代码 @@##@@ @@##@@ @@##@@ 1 2 3 数字焦点图轮播代码就是这么多了,更多精彩请关注创想鸟其它相关文章! 相关阅读: …

    好文分享 2025年12月21日
    000
  • C/C++中的数字连线游戏?

    游戏 – 假设有一个 n × n 的方格数组。其中,一些方格是空的,一些是实心的,还有一些非实心的方格由整数 1、2、3、… 设置。每个整数在棋盘上保持或占据恰好两个不同的方格。玩家的任务是借助仅实现水平和垂直移动的简单路径来连接棋盘上每个整数的两次出现。不允许两条不同的路径…

    2025年12月17日
    000
  • 一个数字连线游戏?

    数字连接是一种逻辑谜题,涉及在网格中找到连接数字的路径。 Numberlink谜题的一个简单例子 Numberlink谜题的解答 规则 – 玩家必须用单一连续线(或路径)将网格上的所有匹配数字配对。线条不能分叉或交叉,并且数字必须位于每条线的末端(即不在中间)。只有当问题具有唯一解并且网…

    2025年12月17日
    000
  • C++程序用于计算使数字n变为1所需的最小操作次数

    假设我们有一个数字n。我们任意执行这些操作之一 – 当 n 可被 2 整除时,将 n 替换为 n/2 当 n 可被 3 整除时,将 n 替换为 2n/3 当 n 可被 5 整除时,将 n 替换为 4n/5 立即学习“C++免费学习笔记(深入)”; li> 我们必须计算出数字 1 所…

    2025年12月17日
    100
  • 使用堆栈在C++中反转一个数字

    We are given an integer number Num as input. The goal is to find the reverse of the number using stack. Stack:- A stack is a data structure in C++ whi…

    2025年12月17日
    000
  • 找出在范围内不可被任何数整除的数字,使用C++

    在本文中,我们将讨论查找 1 到 n(给定)之间的数字的问题,这些数字不能被 2 到 10 之间的任何数字整除。让我们通过一些例子来理解这一点 – Input : num = 14Output : 3Explanation: There are three numbers, 1, 11,…

    2025年12月17日
    000
  • C++程序将一个数字四舍五入到n位小数

    在任何语言中编写程序时,将数字表示为输出是一项有趣且重要的任务。对于整数类型(short、long或medium类型的数据),很容易将数字表示为输出。对于浮点数(float或double类型),有时我们需要将其四舍五入到特定的小数位数。例如,如果我们想将52.24568表示为三位小数,需要进行一些预…

    2025年12月17日
    000
  • 给定一个字符串,其中字母的表示方式被打乱的数字

    在今天的文章中,我们将深入探讨与C++中字符串操作相关的一个独特问题。这个问题是“在给定字符串中,字母表达式被打乱的数字。” 这个问题可以作为一个很好的练习,来提高你在C++中的字符串操作和数据结构技能。 问题陈述 给定一个字符串,任务是识别其中字母表达方式被打乱的数字。例如,如果输入字符串是&#8…

    2025年12月17日
    000
  • 递归程序在C++中检查一个数字是否是回文数

    我们得到一个整数作为输入。目标是使用递归来确定输入数字 Num 是否为回文。 要检查一个数字是否为回文,请反转该数字并检查两个数字是否相同。如果反转后的数等于原数,则为回文。 示例 输入− Num = 34212; 输出− 34212 不是回文! 解释− 如果我们反转 34212,则得到 21243…

    2025年12月17日
    000
  • C程序用于判断给定的数字是否为强数

    一个强数是一个数字,其中各位数字的阶乘之和等于该数字本身。 示例 123!= 1!+2!+3!                    =1+2+6 =9 在这个例子中,123不是一个强数,因为各位数字的阶乘之和不等于该数字本身。 145!=1!+4!+5!             =1+24+120…

    2025年12月17日
    000
  • 找到通过插入给定数字形成的最小数字

    在给定的数字中插入一个数字意味着在给定的数字中添加一个新的数字,可以是在数字的前面、后面或者中间。我们已经给出了一个数字和一个数字,并且必须以尽可能小的方式将该数字添加到数字中。为了方便插入操作,我们将把数字转换为字符串。此外,给定的数字也可以是负数,因此我们必须考虑这种情况。 示例示例 Input…

    2025年12月17日
    000
  • 最长非递增子序列在一个二进制字符串中

    在这个问题中,我们需要找到给定字符串的最长非递增子序列。 非递增的意思是字符要么相同,要么按降序排列。由于二进制字符串仅包含“0”和“1”,因此生成的字符串应以“1”开头并以“0”结尾,或者以“0”或“1”开头和结尾。 为了解决这个问题,我们将统计字符串每个位置的前缀“1”和后缀“0”,并找到前缀“…

    2025年12月17日
    000
  • 打印给定数字的乘法表在C中

    程序描述 打印给定数字的乘法表 算法 接受用户提供的任何需要形成乘法的数字 从 I 的值开始乘以给定数 (=1) 将给定数与 I 的值递增,直到 I 值小于或等于12. 示例 /* Program to print the multiplication table of a given number…

    2025年12月17日
    000
  • 给定一个数字,编写一个C程序来找到斐波那契数列

    斐波那契数列是通过将前两个数字相加得到的一系列数字。 斐波那契数列从两个数字f0和f1开始。 fo和f1的初始值可以取0、1或1、1。 Fibonacci序列满足以下条件: fn = fn-1 + fn-2 算法 参考Fibonacci序列的算法。 STARTStep 1: Read integer…

    2025年12月17日
    000
  • 可憎的数字

    如果一个数字在其二进制展开中有奇数个1,则被认为是奇异数。前10个奇异数是1,2,4,7,10,11,13,14,16,19,21。有趣的是,所有2的幂都是奇异数,因为它们只有1个位被设置。 下面的文章详细讨论了两种判断一个数字是否为可恶数字的方法。 问题陈述 这个问题的目的是检查给定的数字是否是一…

    2025年12月17日
    000
  • 用C++将一个数字表示为最大可能数量的质数之和

    讨论一个问题,例如,给定一个数字 N,我们需要将该数字拆分为最大素数和 Input: N = 7Output: 2 2 3Explanation: 7 can be represented as the sum of two 2’s and a 3 which are the maxim…

    2025年12月17日
    000
  • 使用C++编写代码,找到第N个非平方数

    我们都知道不是任何数字的平方的数字,如 2、3、5、7、8 等。非平方数有 N 个,不可能知道每个数字。因此,在本文中,我们将解释有关无平方数或非平方数的所有内容,以及在 C++ 中查找第 N 个非平方数的方法。 第 N 个非平方数 如果一个数是整数的平方,则该数被称为完全平方数。完全平方数的一些例…

    2025年12月17日
    000
  • 将一个以链表表示的数字加1

    数字的链表表示是这样提供的:链表的所有节点都被视为数字的一位数字。节点存储数字,使得链表的第一个元素保存数字的最高有效位,链表的最后一个元素保存数字的最低有效位。例如,数字 202345 在链表中表示为 (2->0->2->3->4->5)。 要向这个表示数字的链表添加…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信