​LeetCode解法汇总1702. 修改后的最大二进制字符串

news/2024/7/5 2:06:45

目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:. - 力扣(LeetCode)


描述:

给你一个二进制字符串 binary ,它仅有 0 或者 1 组成。你可以使用下面的操作任意次对它进行修改:

  • 操作 1 :如果二进制串包含子字符串 "00" ,你可以用 "10" 将其替换。
    • 比方说, "00010" -> "10010"
  • 操作 2 :如果二进制串包含子字符串 "10" ,你可以用 "01" 将其替换。
    • 比方说, "00010" -> "00001"

请你返回执行上述操作任意次以后能得到的 最大二进制字符串 。如果二进制字符串 x 对应的十进制数字大于二进制字符串 y 对应的十进制数字,那么我们称二进制字符串 x 大于二进制字符串 y 

示例 1:

输入:binary = "000110"
输出:"111011"
解释:一个可行的转换为:
"000110" -> "000101" 
"000101" -> "100101" 
"100101" -> "110101" 
"110101" -> "110011" 
"110011" -> "111011"

示例 2:

输入:binary = "01"
输出:"01"
解释:"01" 没办法进行任何转换。

提示:

  • 1 <= binary.length <= 105
  • binary 仅包含 '0' 和 '1' 。

解题思路:

我们从字符串左边第一位开始依次遍历,如果是1则不用改变,如果是0,我们则想办法将其变成1。
我们会找到下一位出现的0,利用操作2 我们可以使得这两个0相邻,再使用操作1使得00变成10。
我们依次执行这个操作,直到字符串中没有第二个0,或者达到字符串结尾。

代码:

class Solution {
public:
    string maximumBinaryString(string binary)
    {
        const char *c = binary.c_str();
        int pre1Num = 0;
        int zeroNum = 0;
        int suf1Num = 0;
        while (*c != '\0')
        {
            if (*c == '0')
            {
                zeroNum++;
            }
            else if (zeroNum == 0)
            {
                pre1Num++;
            }
            else
            {
                suf1Num++;
            }
            c++;
        }
        if (zeroNum == 0)
        {
            return binary;
        }
        string out = "";
        out.append(pre1Num, '1');
        out.append(zeroNum - 1, '1');
        out.append("0");
        out.append(suf1Num, '1');
        return out;
    }
};


http://lihuaxi.xjx100.cn/news/2159734.html

相关文章

【C++入门】内联函数、auto与基于范围的for循环

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

S参数通俗讲义

原文来自微信公众号&#xff1a;工程师看海&#xff0c;与我联系&#xff1a;chunhou0820 看海原创视频教程&#xff1a;《运放秘籍》 大家好&#xff0c;我是工程师看海。 介绍信号完整性就必须说说S参数&#xff0c;在我们仿真和测试中经常会用的S参数&#xff0c;S参数的全…

Centos7.9 OpenSSH 安全漏洞(CVE-2023-38408)

因为CVE-2023-38408&#xff0c;需要升级升级OpenSSH版本&#xff1a; yum groupinstall -y "Development Tools" yum install -y zlib-devel openssl-devel wgetcp /etc/ssh/sshd_config /etc/ssh/sshd_config.bak chmod 600 /etc/ssh/ssh_host_rsa_key chmod 600…

聊一聊java中的SortedMap,TreeMap,以及SortedSet和TreeSet

SortedMap、TreeMap、SortedSet和TreeSet都是Java集合框架中的重要组成部分&#xff0c;它们各自具有独特的特点和适用场景。 下面将逐一详细介绍这些集合类的特点。 SortedMap SortedMap是Java中的一个接口&#xff0c;它继承自Map接口&#xff0c;用于存储键值对&#xff0…

2024.4.3力扣每日一题——找出克隆二叉树中的相同节点

2024.4.3 题目来源我的题解方法一 深度优先搜索方法二 广度优先遍历 题目来源 力扣每日一题&#xff1b;题序&#xff1a;1379 我的题解 方法一 深度优先搜索 同时对二叉树 original 与 cloned 进行深度优先搜索&#xff0c;如果 original当前搜索的节点的引用等于 target 节…

python 怎样卸载pip

首先&#xff0c;同时按下键盘&#xff0c;winR 调出运行窗口&#xff0c;输入‘cmd’命令。 想在cmd界面进行解析&#xff0c;必须将python环境变量安装好&#xff0c;可以通过输入‘python’来确定是否调整好变量。 首先将python的工作路径调整值&#xff0c;所需安装工具包位…

茴香豆 RAG 智能助理 搭建

一. 环境准备 1. 构建Conda环境 studio-conda -o internlm-base -t InternLM2_Huixiangdou 2. 进入创建的conda环境 conda activate InternLM2_Huixiangdou 二. 准备基础文件 1. 创建文件夹 cd /root && mkdir models 2. 构建软链接 # 复制BCE模型 ln -s /root…

蓝桥杯 基础练习 特殊的数字

资源限制 内存限制&#xff1a;512.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述 153是一个非常特殊的数&#xff0c;它等于它的每位数字的立方和&#xff0c;即1531*1*15*5*53*3*3。编程求所有满足这种条件…