0

0

移除二进制字符串中所有的0所需的最小非相邻对翻转次数

WBOY

WBOY

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

|

766人浏览过

|

来源于tutorialspoint

转载

移除二进制字符串中所有的0所需的最小非相邻对翻转次数

在二进制字符串中,翻转一对相邻位可以轻松地从字符串中删除单个 0。然而,当我们需要从二进制字符串中删除所有 0 时,我们可能还需要翻转不相邻的位对。在本文中,我们将讨论如何确定从二进制字符串中删除所有 0 所需的非相邻对翻转的最小次数。

算法

为了解决这个问题,我们将使用一个简单的贪心算法。这个想法是始终选择彼此相距最远并且之间至少有一个 0 的一对位。然后我们可以翻转这两位,有效地从字符串中删除一个 0。我们重复这个过程,直到所有的 0 都被删除。

现在让我们用 C++ 实现这个算法。

示例

#include 
#include 

using namespace std;

int main() {
   string s;
   s="100101000";
   int n = s.size();
   
   int cnt = 0;
   for (int i = 0; i < n; i++) {
      if (s[i] == '0') {
         cnt++;
         if (i+2 < n && s[i+2] == '0') {
            i += 2;
         }
         else {
            i++;
         }
      }
   }
   
   cout << cnt << endl;
   return 0;
}

输出

3

代码说明

上面的代码采用二进制字符串作为输入,并计算从字符串中删除所有 0 所需的非相邻对翻转的最小次数。现在让我们详细了解代码。

首先,我们将二进制字符串作为输入并将其存储在字符串变量“s”中。我们还将字符串的大小存储在整数变量“n”中。

string s;
cin >> s;
int n = s.size();

接下来,我们初始化变量“cnt”来存储字符串中 0 的数量。然后我们使用 for 循环迭代该字符串。对于遇到的每个 0,我们都会增加 0 的计数并检查接下来的两位是否也是 0。如果是,我们通过将索引增加 2 来翻转这对位。否则,我们通过将索引增加 1 来仅翻转相邻的位对。

ghiblitattoo
ghiblitattoo

用AI创造独特的吉卜力纹身

下载
int cnt = 0;
for (int i = 0; i < n; i++) {
   if (s[i] == '0') {
      cnt++;
      if (i+2 < n && s[i+2] == '0') {
         i += 2;
      }
      else {
         i++;
      }
   }
}

最后,我们输出从字符串中删除所有 0 所需的非相邻对翻转的计数。

cout << cnt << endl;

测试用例示例

让我们考虑二进制字符串“100101000”。可以使用上述算法计算从该字符串中删除所有 0 所需的非相邻对翻转的最小次数。

首先,我们在位置 2 处遇到 0。我们翻转 (1,3) 对以得到字符串“110101000”。然后我们在位置 5 处遇到下一个 0。我们翻转 (1,7) 对以得到字符串“111101000”。然后我们在位置 8 处遇到下一个 0。我们翻转 (1,9) 对以得到字符串“111111000”。现在所有 0 都已从字符串中删除。

从字符串中删除所有 0 所需的非相邻对翻转次数为 3。我们可以通过对输入字符串“100101000”运行上述 C++ 代码来验证这一点。

结论

在本文中,我们讨论了如何确定从二进制字符串中删除所有 0 所需的非相邻对翻转的最小次数。我们使用简单的贪心算法来解决这个问题,并用C++代码实现。我们还提供了一个示例测试用例来说明算法的工作原理。

相关专题

更多
C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

29

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

8

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

55

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
麻省理工大佬Python课程
麻省理工大佬Python课程

共34课时 | 5.2万人学习

【web前端】Node.js快速入门
【web前端】Node.js快速入门

共16课时 | 2万人学习

php-src源码分析探索
php-src源码分析探索

共6课时 | 0.5万人学习

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

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