搜索
首页后端开发C++通过从给定的二进制字符串中选择相等长度的子字符串,最大化给定函数

通过从给定的二进制字符串中选择相等长度的子字符串,最大化给定函数

给定两个相同长度的二进制字符串 str1 和 str2,我们必须通过从给定的相同长度的字符串中选择子字符串来最大化给定的函数值。给定的函数是这样的 -

fun(str1, str2) = (len(子字符串))/(2^xor(sub1, sub2))。

这里,len(substring) 是第一个子字符串的长度,而 xor(sub1, sub2) 是给定子字符串的异或,因为它们是二进制字符串,所以这是可能的。

示例

Input1: string str1 = 10110 & string str2 = 11101 
Output: 3

说明

我们可以选择许多不同的字符串集来找到解决方案,但从两个字符串中选择“101”将使异或为零,这将导致函数返回最大值。

Input2: string str1 = 11111, string str2 = 10001 
Output: 1 

说明

我们可以选择“1”作为子字符串,这将导致此输出,如果我们选择任何其他字符串,则会产生较低的值。

天真的方法

在这种方法中,我们将找到所有子字符串,然后比较它们以找到解决方案,但这种解决方案效率不高,并且会花费大量时间和空间复杂度。

生成长度 x 平均时间复杂度的子串是 N^2,然后比较每个子串将花费 N^2 多。另外,我们还必须找到给定子字符串的异或,这也会花费额外的 N 因子,这意味着 N^5 将是上述代码的时间复杂度,效率非常低。

高效的方法

想法

这里的想法来自于一个简单的观察,即随着异或值变高,它总是会减少答案。因此,为了最大化函数返回值,我们必须尽可能减少异或值。

在两个子串都为零的情况下,可以实现的最小 XOR 值为零。所以,这个问题实际上是由最长公共子串问题衍生出来的。

当异或为零时,被除数部分为1,因此最终答案将是最大公共子串的长度。

实施

我们已经看到了解决问题的想法,让我们看看实现代码的步骤 -

  • 我们将创建一个函数,它将接受两个给定的字符串作为输入并返回整数值,这将是我们的最终结果。

  • 在函数中,我们首先获取字符串的长度,然后创建一个与给定字符串相乘的大小的二维向量。

  • 我们将使用嵌套的 for 循环来遍历字符串并获取最大的公共子字符串。

  • 在每次迭代时,我们将检查两个字符串的当前索引是否匹配,然后我们将从两个字符串的最后一个索引的向量中获取值。

  • 否则,我们只会将向量的当前索引设为零。

  • 此外,我们将维护一个变量来维护公共子字符串最大长度的计数。

  • 最后,我们将返回答案并在主函数中打印它。

示例

#include <bits/stdc++.h>
using namespace std;
// function to get the result
int result(string str1, string str2){
   int n = str1.length(); // size of the first string
   int m = str2.length(); // size of the second string   
   
   // creating vector to store the dynamic programming results 
   vector<vector<int>>dp(n+1, vector<int>(m+1)); 
   int ans = 0; // variable to store the result 
   
   // traversing over the strings using nested for loops 
   for (int i = 1; i <= n; i++){
      for (int j = 1; j <= m; j++){ 
      
         // if current elements of both the string are equal 
         if (str1[i - 1] == str2[j - 1]){
            // getting one maximum of the last two 
            dp[i][j] = 1 + dp[i - 1][j - 1];
            ans = max(ans, dp[i][j]);
         }
      }
   }
   return ans; // return the final answer or count 
} 
int main(){
   string str1 = "10110";
   string str2 = "11101"; 
   
   // calling the function
   cout<<"The maximum score for a given function by selecting equal length substrings from given binary strings is "<< result(str1,str2)<<endl;
   return 0;
}

输出

The maximum score for a given function by selecting equal length substrings from given binary strings is 3

时间和空间复杂度

上述代码的时间复杂度为 O(N^2),因为我们使用嵌套的 for 循环,每次迭代 N 次。

由于我们使用二维数组来存储元素,因此上述代码的空间复杂度为 O(N^2)。

结论

在本教程中,我们通过从给定的二进制字符串中选择等长的子字符串来实现给定函数的最大分数的代码。我们已经讨论过这种幼稚的方法,这种方法效率极低。根据给定的函数,异或的值越小,因此我们通过在O(N^2)时间复杂度内获取最长公共子串来使异或为零。

以上是通过从给定的二进制字符串中选择相等长度的子字符串,最大化给定函数的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:tutorialspoint。如有侵权,请联系admin@php.cn删除
C中的XML:处理复杂的数据结构C中的XML:处理复杂的数据结构May 02, 2025 am 12:04 AM

在C 中处理XML数据结构可以使用TinyXML或pugixml库。1)使用pugixml库解析和生成XML文件。2)处理复杂的嵌套XML元素,如书籍信息。3)优化XML处理代码,建议使用高效库和流式解析。通过这些步骤,可以高效处理XML数据。

C和性能:它仍然主导C和性能:它仍然主导May 01, 2025 am 12:14 AM

C 在性能优化方面仍然占据主导地位,因为其低级内存管理和高效执行能力使其在游戏开发、金融交易系统和嵌入式系统中不可或缺。具体表现为:1)在游戏开发中,C 的低级内存管理和高效执行能力使得它成为游戏引擎开发的首选语言;2)在金融交易系统中,C 的性能优势确保了极低的延迟和高吞吐量;3)在嵌入式系统中,C 的低级内存管理和高效执行能力使得它在资源有限的环境中非常受欢迎。

C XML框架:为您选择合适的一个C XML框架:为您选择合适的一个Apr 30, 2025 am 12:01 AM

C XML框架的选择应基于项目需求。1)TinyXML适合资源受限环境,2)pugixml适用于高性能需求,3)Xerces-C 支持复杂的XMLSchema验证,选择时需考虑性能、易用性和许可证。

C#vs. C:为您的项目选择正确的语言C#vs. C:为您的项目选择正确的语言Apr 29, 2025 am 12:51 AM

C#适合需要开发效率和类型安全的项目,而C 适合需要高性能和硬件控制的项目。 1)C#提供垃圾回收和LINQ,适用于企业应用和Windows开发。 2)C 以高性能和底层控制着称,广泛用于游戏和系统编程。

c  怎么进行代码优化c 怎么进行代码优化Apr 28, 2025 pm 10:27 PM

C 代码优化可以通过以下策略实现:1.手动管理内存以优化使用;2.编写符合编译器优化规则的代码;3.选择合适的算法和数据结构;4.使用内联函数减少调用开销;5.应用模板元编程在编译时优化;6.避免不必要的拷贝,使用移动语义和引用参数;7.正确使用const帮助编译器优化;8.选择合适的数据结构,如std::vector。

如何理解C  中的volatile关键字?如何理解C 中的volatile关键字?Apr 28, 2025 pm 10:24 PM

C 中的volatile关键字用于告知编译器变量值可能在代码控制之外被改变,因此不能对其进行优化。1)它常用于读取可能被硬件或中断服务程序修改的变量,如传感器状态。2)volatile不能保证多线程安全,应使用互斥锁或原子操作。3)使用volatile可能导致性能slight下降,但确保程序正确性。

怎样在C  中测量线程性能?怎样在C 中测量线程性能?Apr 28, 2025 pm 10:21 PM

在C 中测量线程性能可以使用标准库中的计时工具、性能分析工具和自定义计时器。1.使用库测量执行时间。2.使用gprof进行性能分析,步骤包括编译时添加-pg选项、运行程序生成gmon.out文件、生成性能报告。3.使用Valgrind的Callgrind模块进行更详细的分析,步骤包括运行程序生成callgrind.out文件、使用kcachegrind查看结果。4.自定义计时器可灵活测量特定代码段的执行时间。这些方法帮助全面了解线程性能,并优化代码。

C  中的chrono库如何使用?C 中的chrono库如何使用?Apr 28, 2025 pm 10:18 PM

使用C 中的chrono库可以让你更加精确地控制时间和时间间隔,让我们来探讨一下这个库的魅力所在吧。C 的chrono库是标准库的一部分,它提供了一种现代化的方式来处理时间和时间间隔。对于那些曾经饱受time.h和ctime折磨的程序员来说,chrono无疑是一个福音。它不仅提高了代码的可读性和可维护性,还提供了更高的精度和灵活性。让我们从基础开始,chrono库主要包括以下几个关键组件:std::chrono::system_clock:表示系统时钟,用于获取当前时间。std::chron

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。