目录
算法
示例
输出
代码说明
测试用例示例
结论
首页 后端开发 C++ 移除二进制字符串中所有的0所需的最小非相邻对翻转次数

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

Sep 04, 2023 pm 01:09 PM
二进制 翻转 非相邻

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

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

算法

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

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

示例

#include <iostream>
#include <cstring>

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 来仅翻转相邻的位对。

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++代码实现。我们还提供了一个示例测试用例来说明算法的工作原理。

以上是移除二进制字符串中所有的0所需的最小非相邻对翻转次数的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热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

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

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

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

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

深空之眼怎么翻转屏幕 深空之眼怎么翻转屏幕 Mar 22, 2024 pm 10:41 PM

玩家在深空之眼中进行游戏时可以翻转屏幕进行游戏,有很多用户不知道深空之眼怎么翻转屏幕,玩家需要在控制中心打开支持屏幕旋转的选项,再回到游戏中即可。深空之眼怎么翻转屏幕1、打开手机的屏幕,用手指从屏幕底部向上滑动。2、随后即可打开控制中心了,在控制中心的右上角就是关闭屏幕旋转的开关。3、点击它即可打开屏幕旋转,此时会发现控制旋转的图标在控制中心以高亮显示。4、打开支持屏幕旋转的应用软件时,就会随着手机方向的改变而旋转了。

二进制算法怎么算 二进制算法怎么算 Jan 19, 2024 pm 04:38 PM

二进制算法是一种基于二进制数的运算方法,其基本运算包括加法、减法、乘法和除法。除了基本运算外,二进制算法还包括逻辑运算、位移运算等操作。逻辑运算包括与、或、非等操作,位移运算包括左移和右移操作。这些操作都有对应的规则和操作数的要求。

如何通过纯CSS实现图片的翻转效果的方法和技巧 如何通过纯CSS实现图片的翻转效果的方法和技巧 Oct 20, 2023 am 10:57 AM

如何通过纯CSS实现图片的翻转效果的方法和技巧前言:在Web开发中,我们经常需要为网页添加一些动画效果来增加用户体验。图片的翻转效果是其中一个常见的效果之一。通过纯CSS来实现图片的翻转不仅简单方便,还可以避免使用JavaScript等其他语言带来的额外开销。本文将介绍如何通过纯CSS实现图片的翻转效果,并提供具体的代码示例。一、利用CSS3的transfo

如何使用C语言将二进制转换为十六进制? 如何使用C语言将二进制转换为十六进制? Sep 01, 2023 pm 06:57 PM

二进制数以1和0表示。16位的十六进制数系统为{0,1,2,3…..9,A(10),B(11),……F(15)}为了从二进制表示转换为十六进制表示,位串id被分组为4位块,从最低有效侧开始称为半字节。每个块都替换为相应的十六进制数字。让我们看一个示例,以清楚地了解十六进制和二进制数字表示。001111100101101100011101 3  E  5  B&nb

EDVAC有哪两个重大的改进 EDVAC有哪两个重大的改进 Mar 02, 2023 pm 02:58 PM

EDVAC的两个重大的改进:一是采用二进制,二是完成了存贮程序,可以自动地从一个程序指令进到下一个程序指令,其作业可以通过指令自动完成。“指令”包括数据和程序,把它们用码的形式输入到机器的记忆装置中,即用记忆数据的同一记忆装置存贮执行运算的命令,这就是所谓存贮程序的新概念。

HTML、CSS和jQuery:构建一个漂亮的卡片翻转特效 HTML、CSS和jQuery:构建一个漂亮的卡片翻转特效 Oct 27, 2023 pm 01:43 PM

HTML、CSS和jQuery:构建一个漂亮的卡片翻转特效在网页设计中,特效的应用可以增加页面的交互性和视觉效果。卡片翻转特效是一种常见的特效,它可以给用户带来更生动、有趣的浏览体验。本文将介绍如何使用HTML、CSS和jQuery构建一个漂亮的卡片翻转特效,并提供具体的代码示例。首先,我们需要准备好HTML的基本结构。我们将使用两个div元素来表示卡片的正

Golang如何读取二进制文件? Golang如何读取二进制文件? Mar 21, 2024 am 08:27 AM

Golang如何读取二进制文件?二进制文件是以二进制形式存储的文件,其中包含了计算机能够识别和处理的数据。在Golang中,我们可以使用一些方法来读取二进制文件,并将其解析成我们想要的数据格式。下面将介绍如何在Golang中读取二进制文件,并给出具体的代码示例。首先,我们需要使用os包中的Open函数打开一个二进制文件,这将返回一个文件对象。然后,我们可以使

计算机内部采用二进制的主要原因是什么? 计算机内部采用二进制的主要原因是什么? Apr 04, 2019 pm 02:25 PM

计算机采用二进制的主要原因:1、计算机是由逻辑电路组成,逻辑电路通常只有两个状态,开关的接通与断开,这两种状态正好可以用“1”和“0”表示;2、二进制中只使用0和1两个数字,传输和处理时不易出错,因而可以保障计算机具有很高的可靠性。

See all articles