最长非递增子序列在一个二进制字符串中
在这个问题中,我们需要找到给定字符串的最长非递增子序列。
非递增的意思是字符要么相同,要么按降序排列。由于二进制字符串仅包含“0”和“1”,因此生成的字符串应以“1”开头并以“0”结尾,或者以“0”或“1”开头和结尾。
为了解决这个问题,我们将统计字符串每个位置的前缀“1”和后缀“0”,并找到前缀“1”和后缀“0”的最大和。
问题陈述 - 我们给出了二进制字符串 str。我们需要从给定的字符串中找到最长的非递增子序列。
示例
Input – str = "010100"
Output – 4
说明
最长的非递增子序列是“1100”。
Input – str = "010110010"
Output – 6
说明
最长的非递增子序列是“111000”。
Input – str = ‘00000000’
Output – 8
说明
最长的非递增子序列是‘00000000’,它等于给定的字符串。
方法 1
在这种方法中,我们将在数组中为每个索引存储前缀“1”和后缀“0”的计数。之后,我们从两个数组中的相同索引获取值,将它们相加,并找到最大总和。
算法
步骤 1 - 定义 pre1s 和 suffix0s 数组来存储前缀 1 和后缀 0。另外,将所有数组元素初始化为 0。
步骤 2 - 使用 for 循环遍历字符串并计算每个索引的前缀 1。如果我> 0,则将前一个元素的值添加到当前元素。
步骤 3 - 如果当前字符为“1”,则将 pre1s[i] 的当前值加 1。
第 4 步 - 现在,计算给定字符串中的后缀 0。从末尾开始遍历字符串。
步骤 5 - 如果“I”的值不等于“n – 1”,则获取“I + 1”元素的值并将其添加到当前元素。
第 6 步 - 如果当前元素为“0”,则向当前元素加 1。
第 7 步 - 现在,用 0 初始化“res”变量。
第 8 步 - 使用循环迭代“pre1s”和“suffix0s”。
第 9 步 - 从“pre1s”和“suffix0s”数组中的第 i 个索引获取值,并将它们相加。另外,如果“sum”大于“res”变量的当前值,则用“sum”值更改“res”变量值。
第 10 步 - 返回“res”变量的值。
示例
对于输入‘010100’,前缀数组为 [0, 1, 1, 2, 2, 2],后缀 0 数组为 [4, 3, 3, 2, 2, 1]。 sum 数组将为 [4, 4, 4, 4, 4, 1],sum 数组中的最大值为 4。因此,答案将为 4。
#include <bits/stdc++.h> using namespace std; int getMaxLength(string str, int n){ // To store the prefix count of '1's and suffix count of '0's int pre1s[n] = {0}, suffix0s[n] = {0}; for (int i = 0; i < n; i++){ // get the prefix count of '1's if (i > 0){ pre1s[i] += pre1s[i - 1]; } // If the current character is '1', then update the pre1s array by adding 1; else, keep it as it is. if (str[i] == '1'){ pre1s[i] += 1; } } // get suffix count of '0's for (int i = n - 1; i >= 0; i--) { // add the suffix count of '0's if (i != n - 1) suffix0s[i] += suffix0s[i + 1]; // If the current character is '0', then update the suffix0s array by adding 1; else, keep it as it is. if (str[i] == '0') suffix0s[i] += 1; } // to store the final result value int res = 0; // iterate over the pre1s[] and suffix0s[] array and find the maximum value of pre1s[i] + suffix0s[i] for (int i = 0; i < n; i++){ res = max(res, pre1s[i] + suffix0s[i]); } // Return the result return res; } // Driver Code int main(){ string str = "010100"; int N = str.length(); cout << "The length of the longest non-increasing subsequence in the given binary string is - " << getMaxLength(str, N); return 0; }
输出
The length of the longest non-increasing subsequence in the given binary string is - 4
时间复杂度 - O(N),因为我们需要初始化前缀 1 和后缀 0 的数组。
空间复杂度 - O(N),因为我们将前缀 1 和后缀 0 存储在数组中
方法2
在这种方法中,我们将首先计算零的总数。之后,我们开始遍历字符串,继续计算“1”,如果找到 0,则减少“0”。此外,我们在每次迭代中将 0 和 1 的计数相加,并找到最大结果值。
算法
第 1 步 - 定义 'count1'、'count0' 和 'res' 变量,并用 0 初始化它们,分别存储 1、0 的计数和最终结果.
第 2 步 - 通过遍历字符串并将其存储在“count0”变量中来计算零的总数。
第 3 步 - 现在,使用循环迭代字符串。
步骤 4 - 在循环中,如果当前字符为“1”,则将“count1”的值增加 1,否则将“count0”的值减少1.
第 5 步 - 另外,将“res”和“count0 + count1”中的最大值存储到“res”变量中。
第 6 步 - 当循环终止时,返回“res”变量的值。
示例
#include <bits/stdc++.h> using namespace std; int getMaxLength(string str, int n){ int count1 = 0, count0 = 0; int res = 0; // counting total zeros in the string for (int i = 0; i < n; i++){ if (str[i] == '0') count0++; } // counting 1s from left, subtracting zeros from total zeros and adding both counts. for (int i = 0; i < n; i++){ if (str[i] == '1') count1++; else count0--; res = max(res, count1 + count0); } return res; } int main(){ string str = "010110010"; int N = str.length(); cout << "The length of the longest non-increasing subsequence in the given binary string is - " << getMaxLength(str, N); return 0; }
输出
The length of the longest non-increasing subsequence in the given binary string is - 6
时间复杂度 - O(N),因为我们计算字符串中零的总数并遍历字符串以找到最长的子序列。
空间复杂度 - O(1)
结论
这里,两种方法具有相同的时间复杂度但不同的空间复杂度。第二种方法在我们优化代码时使用常量空间,但第一种方法使用动态空间来存储前缀 1 和后缀 0 的总数。
以上是最长非递增子序列在一个二进制字符串中的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

小红书作为一个生活方式分享平台,越来越多的用户选择在这里发布自己的视频内容,与其他用户分享生活点滴。许多用户在发布视频时,可能会遇到一个问题:如何查看自己或他人发布视频的时间?一、如何查看小红书发布视频的时间?1.查看自己发布视频的时间要查看自己发布视频的时间,首先要打开小红书应用并登录个人账号。在个人主页界面下方,会有一个标有“创作”字样的选项,点击进入后,会看到一个名为“视频”的栏目。在这里,你可以浏览所有已发布的视频列表,并轻松查阅发布时间。每个视频的右上角都有一个“查看详情”按钮,点击后

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

pack()函数将数据打包到二进制字符串中。语法pack(format,args)参数格式-要使用的格式。以下是可能的值-a-NUL填充字符串A-空格填充字符串h-十六进制字符串,低半字节在前H-十六进制字符串,高半字节在前c-带符号字符C-无符号字符s-带符号短字符(始终为16位,机器字节顺序)S-无符号短整型(始终为16位,机器字节顺序)n-无符号短整型(始终为16位,大端字节顺序)v-无符号短整型(始终为16位,小端字节顺序)i-有符号整数(取决于机器的大小和字节顺序)I-无符号整数(取决

在给定的问题中,我们得到一个由0和1组成的字符串;我们需要找到以1开头的所有排列的总数。由于答案可能是一个巨大的数字,所以我们将其取模1000000007后输出。Input:str="10101001001"Output:210Input:str="101110011"Output:56我们将通过应用一些组合数学和建立一些公式来解决这个问题。解决方案的方法在这个方法中,我们将计算0和1的数量。现在假设n是我们字符串中出现的1的数量,m是我们字符串中出现的0

问题陈述我们有一个字符串str和一个二进制字符串B。两个字符串的长度都等于N。我们需要检查是否可以通过在字符串B中包含不相等字符的任意索引对上多次交换其字符,使字符串str成为回文字符串。示例示例输入str=‘AAS’B=‘101’输出‘YES’Explanation的中文翻译为:解释我们可以交换str[1]和str[2],因为B[1]和B[2]不相等。最终的字符串可以是'ASA'。输入str=‘AASS’B=‘1111’输出‘No’Explanation的中文翻译为:解释我们无法使字符串回文,

给定两个相同长度的二进制字符串str1和str2,我们必须通过从给定的相同长度的字符串中选择子字符串来最大化给定的函数值。给定的函数是这样的-fun(str1,str2)=(len(子字符串))/(2^xor(sub1,sub2))。这里,len(substring)是第一个子字符串的长度,而xor(sub1,sub2)是给定子字符串的异或,因为它们是二进制字符串,所以这是可能的。示例Input1:stringstr1=10110&stringstr2=11101Output:3说明我们

在本文中,我们将讨论一个有趣的问题,涉及到字符串操作和博弈论领域:“通过删除非空子字符串来清空二进制字符串,找到剩余0最少的玩家”。这个问题探索了使用二进制字符串进行竞技游戏的概念。我们的目标是在游戏结束后找出剩余0最少的玩家。我们将讨论这个问题,提供一个C++代码实现,并通过一个例子来解释这个概念。理解问题陈述给两个玩家一个二进制字符串,他们轮流玩游戏。在每一回合中,玩家移除至少包含一个“1”的非空子串。当字符串变空或字符串中没有“1”时,游戏结束。无法采取行动的玩家输掉游戏。任务是找到最终0

本文的目的是实现一个程序,用于计算由一个子字符串重复连接而成的长度为N的二进制字符串的数量。目标是确定通过重复连接给定文本的单个子字符串,可以创建多少长度为N的二进制字符串,其中N是一个正整数。问题陈述实现一个程序,用于计算重复连接子字符串的长度为N的二进制字符串的数量。示例示例1LetustaketheInput,N=3Output:2Explanation的中文翻译为:解释下面列出了长度为N=3的可行二进制字符串,其中重复连接了一个子字符串。"000":Thesubstr
