0

0

将给定的二进制字符串转换为另一个二进制字符串,最少操作数为翻转除一个以外的所有位

WBOY

WBOY

发布时间:2023-09-04 23:13:06

|

1394人浏览过

|

来源于tutorialspoint

转载

将给定的二进制字符串转换为另一个二进制字符串,最少操作数为翻转除一个以外的所有位

在这个问题中,我们需要通过翻转字符串的字符,将一个二进制字符串转换为另一个二进制字符串。我们可以保存任何设置的位并翻转其他位,并且我们需要计算总操作以通过这样做来实现另一个字符串。

我们可以根据给定字符串中“01”和“10”对的总数来解决问题。

问题陈述- 我们给出了两个长度相同的字符串,分别名为 str1 和 str2,包含“0”和“1”字符,表示二进制字符串。我们需要通过执行以下操作将字符串 str1 转换为 str2。

  • 我们可以选择任何设置的位并翻转所有其他位。翻转位意味着将“0”转换为“1”,将“1”转换为“0”。

  • 如果无法将 str1 转换为 str2,则打印 -1。

示例

输入

str1 = "001001111", str2 = "011111000";

输出

3

解释

  • 在第一个操作中,我们保持第二个索引的“1”不变,并翻转 str1 中的所有其他字符。因此,str1 将是 111110000。

  • 在第二个操作中,我们保持第 0 个索引的“1”不变,并翻转所有其他字符。因此,str1 将是 100001111。

  • 在最后一个操作中,我们将“1”保存在第 5 个索引处。因此,str1 将变为 011111000。

输入

 str1 = "0000", str2 = "1111";

输出

-1

解释- 无法将 str1 转换为 str2,因为 str1 不包含任何要保存的“1”字符。

输入

 str1 = "0111", str2 = "1000";

输出

-1

说明- 无法将 str1 转换为 str2。

方法 1

我们可以通过观察来解决问题。观察结果是,当我们持有任何单个设置位并执行 2 个操作时,我们可以获得相同的字符串。因此,我们需要选择不同的1索引来对字符串进行更改。

此外,我们需要执行 2 次操作才能将 01 对转换为 10。例如,将“1”保留在“01”中。所以,我们得到“11”。之后,将“1”保留在“11”中的第 0 个索引处,这样我们就会得到“10”。

要得到答案,01 ( 0 -> str1, 1 -> str2) 和 10 ( 1 -> str1, 0 -> str2) 应该是相同的。否则,我们可以说答案不存在。

我们的主要目标是最小化“01”和“10”对,因为我们可以通过 2 次操作将“01”转换为“10”。

算法

第 1 步- 定义totalOperatrions() 函数来计算将str1 转换为str2 所需的操作数。

步骤 1.2 - 初始化 count10 和 count01 变量以将“01”和“10”对存储在字符串中。

步骤 1.3 - 遍历字符串并计算两个字符串中的 01 和 10 对。

步骤 1.4− 如果 count10 和 count01 相同,则返回 2*count10。否则返回-1。

第 2 步- 定义minimumOperations() 函数来计算将 str1 转换为 str2 所需的最少操作。

第 3 步- 用最大值初始化“ans”。

第 4 步- 使用原始字符串调用totalOperations() 函数,并将结果存储在“operation1”变量中。如果返回值不等于-1,则将ans和操作1中的最小值存储在ans中。

第 5 步- 现在,我们将修改字符串以最小化 01 和 10 对。因此,定义 stringModification() 函数。

步骤 5.1 - 在函数中,我们找到字符串中的第一对“1ch”,并将“ch”作为参数传递,可以是“0”或“1”。因此,该对应该类似于 1 -> str1 和 ch -> str。

步骤 5.2- 如果未找到“1ch”对,则返回 false。

步骤 5.3 − 如果找到“1ch”对,则保持该对不变并翻转 str1 的其他字符。

第 6 步- 执行 stringModification 函数以保持“11”对不变并翻转其他字符。之后,再次调用totalOperations()函数来查找将str1转换为str2所需的操作。

第 7 步− 如果操作 2 不等于 -1,则将“ans”或“1 + 操作 2”中的最小值存储在“ans”中。这里,我们添加了 1,因为我们使用了一次操作修改了字符串。

第 8 步- 通过保持第一个“10”对不变来修改字符串,并计算操作数。再次为“ans”分配最小值。

步骤 9− 如果“ans”等于 INT_MAX,则返回 −1。否则,返回 ans。

示例

#include 
using namespace std;

// counting 01 and 10 pairs
int totalOperations(string str1, string str2) {
    int len = str1.size();
    int count10 = 0, count01 = 0;
    for (int p = 0; p < len; p++) {
        // If characters at p index are not same
        if (str1[p] != str2[p]) {
            // Increase count01 if 0(str1)-1(str2), else count10 if 1(str1)-0(str2)
            if (str1[p] == '0')
                count01++;
            else
                count10++;
        }
    }
    // If we have euqal number of 01 and 10 pairs, we need 2 operations to flip one pair.
    if (count01 == count10)
        return 2 * count01;
    return -1;
}
bool StringModification(string &temp1, string &temp2, char ch) {
    int len = temp1.size();
    int index = -1;
    // Find the pair of 1c character. (1 -> temp1, c -> temp2)
    for (int p = 0; p < len; p++) {
        if (temp1[p] == '1' && temp2[p] == ch) {
            index = p;
            break;
        }
    }
    // return 0 if pair is not found
    if (index == -1)
        return false;
    // Flip other characters in both strings
    for (int p = 0; p < len; p++) {
        if (p != index) {
            if (temp1[p] == '1')
                temp1[p] = '0';
            else
                temp1[p] = '1';
        }
    }
    return true;
}
// finding minimum operations
int minimumOperations(string str1, string str2) {
    int ans = INT_MAX;
    // first case with initial strings
    int operation1 = totalOperations(str1, str2);
    if (operation1 != -1)
        ans = min(ans, operation1);
    string temp1 = str1, temp2 = str2;
    // Case 2, modification for 11 pair
    if (StringModification(temp1, temp2, '1')) {
        // get operations after modification
        int operation2 = totalOperations(temp1, temp2);
        // adding 1 to operation2 as we have done one modification initially
        if (operation2 != -1)
            ans = min(ans, 1 + operation2);
    }
    // Case 3 modification for 10 pair
    temp1 = str1, temp2 = str2;
    if (StringModification(temp1, temp2, '0')) {
        int operation3 = totalOperations(temp1, temp2);
        if (operation3 != -1)
            ans = min(ans, 1 + operation3);
    }
    if (ans == INT_MAX)
        return -1;
    else
        return ans;
}
int main() {
    string str1 = "001001111";
    string str2 = "011111000";
    int ans = minimumOperations(str1, str2);
    if (ans == -1){
        cout << "S1 to S2 conversion is not possible";
    }
    else{
        cout << "Minimum number of operations required are: " << ans << "\n";
    }
    return 0;
}

输出

Minimum number of operations required are: 3

时间复杂度− O(N),因为我们在 stringModification() 和totalOperations() 函数中遍历字符串。

空间复杂度− O(1),因为我们修改相同的字符串而不使用任何额外的空间。

在代码中,我们的主要目的是在修改字符串后,减少给定字符串中01和10对的数量,以尽量减少操作。程序员可以使用各种输入并尝试理解答案。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

178

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

35

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

79

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

2

2026.01.28

php中文乱码如何解决
php中文乱码如何解决

本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

4

2026.01.28

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

8

2026.01.28

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

24

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

122

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

72

2026.01.26

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
NumPy 教程
NumPy 教程

共44课时 | 3万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

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

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