0

0

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

王林

王林

发布时间:2023-08-28 09:49:06

|

629人浏览过

|

来源于tutorialspoint

转载

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

给定两个相同长度的二进制字符串 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,因此最终答案将是最大公共子串的长度。

实施

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

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

    Type
    Type

    生成草稿,转换文本,获得写作帮助-等等。

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

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

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

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

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

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

示例

#include 
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>dp(n+1, vector(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)<

输出

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)时间复杂度内获取最长公共子串来使异或为零。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

2

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

2

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

0

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

0

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.29

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

25

2026.01.29

clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址
clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址

clawdbot龙虾机器人官网入口:https://clawd.bot/,clawdbot ai是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

16

2026.01.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

8

2026.01.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

622

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Swoft2.x速学之http api篇课程
Swoft2.x速学之http api篇课程

共16课时 | 0.9万人学习

PHP基础入门课程
PHP基础入门课程

共33课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号