目录
示例
说明
方法2
算法
输出
结论
首页 后端开发 C++ 最长非递增子序列在一个二进制字符串中

最长非递增子序列在一个二进制字符串中

Sep 07, 2023 pm 11:13 PM
二进制字符串 最长 非递增子序列

最长非递增子序列在一个二进制字符串中

在这个问题中,我们需要找到给定字符串的最长非递增子序列。

非递增的意思是字符要么相同,要么按降序排列。由于二进制字符串仅包含“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中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何查看小红书发布视频的时间?发布视频时间最长是多少? 如何查看小红书发布视频的时间?发布视频时间最长是多少? Mar 21, 2024 pm 04:26 PM

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

最长非递增子序列在一个二进制字符串中 最长非递增子序列在一个二进制字符串中 Sep 07, 2023 pm 11:13 PM

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

在PHP中,pack()函数的作用是将数据转换为二进制字符串 在PHP中,pack()函数的作用是将数据转换为二进制字符串 Aug 31, 2023 pm 02:05 PM

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

使用C++编写,找到以1开头的二进制字符串的唯一排列数量 使用C++编写,找到以1开头的二进制字符串的唯一排列数量 Sep 05, 2023 am 09:01 AM

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

检查一个字符串是否可以通过交换二进制字符串中具有不相等字符的索引处的字符对来形成回文字符串 检查一个字符串是否可以通过交换二进制字符串中具有不相等字符的索引处的字符对来形成回文字符串 Sep 02, 2023 pm 08:09 PM

问题陈述我们有一个字符串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的中文翻译为:解释我们无法使字符串回文,

通过从给定的二进制字符串中选择相等长度的子字符串,最大化给定函数 通过从给定的二进制字符串中选择相等长度的子字符串,最大化给定函数 Aug 28, 2023 am 09:49 AM

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

找到在将一个二进制字符串清空(通过移除非空子字符串)后,0的数量最少的玩家 找到在将一个二进制字符串清空(通过移除非空子字符串)后,0的数量最少的玩家 Sep 16, 2023 am 10:21 AM

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

计算长度为N的二进制字符串,它们是子字符串的重复拼接 计算长度为N的二进制字符串,它们是子字符串的重复拼接 Sep 07, 2023 am 10:13 AM

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

See all articles