在这个问题中,我们需要通过翻转字符串的字符,将一个二进制字符串转换为另一个二进制字符串。我们可以保存任何设置的位并翻转其他位,并且我们需要计算总操作以通过这样做来实现另一个字符串。
我们可以根据给定字符串中“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 <bits/stdc++.h> 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对的数量,以尽量减少操作。程序员可以使用各种输入并尝试理解答案。
以上是将给定的二进制字符串转换为另一个二进制字符串,最少操作数为翻转除一个以外的所有位的详细内容。更多信息请关注PHP中文网其他相关文章!

在C 项目中集成XML可以通过以下步骤实现:1)使用pugixml或TinyXML库解析和生成XML文件,2)选择DOM或SAX方法进行解析,3)处理嵌套节点和多级属性,4)使用调试技巧和最佳实践优化性能。

在C 中使用XML是因为它提供了结构化数据的便捷方式,尤其在配置文件、数据存储和网络通信中不可或缺。1)选择合适的库,如TinyXML、pugixml、RapidXML,根据项目需求决定。2)了解XML解析和生成的两种方式:DOM适合频繁访问和修改,SAX适用于大文件或流数据。3)优化性能时,TinyXML适合小文件,pugixml在内存和速度上表现好,RapidXML处理大文件优异。

C#和C 的主要区别在于内存管理、多态性实现和性能优化。1)C#使用垃圾回收器自动管理内存,C 则需要手动管理。2)C#通过接口和虚方法实现多态性,C 使用虚函数和纯虚函数。3)C#的性能优化依赖于结构体和并行编程,C 则通过内联函数和多线程实现。

C 中解析XML数据可以使用DOM和SAX方法。1)DOM解析将XML加载到内存,适合小文件,但可能占用大量内存。2)SAX解析基于事件驱动,适用于大文件,但无法随机访问。选择合适的方法并优化代码可提高效率。

C 在游戏开发、嵌入式系统、金融交易和科学计算等领域中的应用广泛,原因在于其高性能和灵活性。1)在游戏开发中,C 用于高效图形渲染和实时计算。2)嵌入式系统中,C 的内存管理和硬件控制能力使其成为首选。3)金融交易领域,C 的高性能满足实时计算需求。4)科学计算中,C 的高效算法实现和数据处理能力得到充分体现。

C 没有死,反而在许多关键领域蓬勃发展:1)游戏开发,2)系统编程,3)高性能计算,4)浏览器和网络应用,C 依然是主流选择,展现了其强大的生命力和应用场景。

C#和C 的主要区别在于语法、内存管理和性能:1)C#语法现代,支持lambda和LINQ,C 保留C特性并支持模板。2)C#自动内存管理,C 需要手动管理。3)C 性能优于C#,但C#性能也在优化中。

在C 中处理XML数据可以使用TinyXML、Pugixml或libxml2库。1)解析XML文件:使用DOM或SAX方法,DOM适合小文件,SAX适合大文件。2)生成XML文件:将数据结构转换为XML格式并写入文件。通过这些步骤,可以有效地管理和操作XML数据。


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

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

热门文章

热工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

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

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

WebStorm Mac版
好用的JavaScript开发工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具