搜索
首页后端开发C++通过重复替换第二位,使二进制字符串相等

通过重复替换第二位,使二进制字符串相等

在这个问题中,我们需要将 bin1 字符串转换为 bin2 字符串,方法是将 bin1 字符串的第二个字符替换为第一个和第二个字符中的最小值或最大值,并删除第一个字符。

由于我们需要删除首字符,因此需要确保两个字符串中最后一个 len2 − 1 字符相同。另外,我们需要确保通过对 bin1 字符串的起始字符执行给定的操作,可以获取第二个字符串的第一个字符。

问题陈述 - 我们分别给出了 len1 和 len2 长度的 bin1 和 bin2 二进制字符串。我们需要检查是否可以通过以下操作将 bin1 字符串转换为 bin2 字符串。

  • 使用 bin1 字符串的第一个和第二个字符中的最小值或最大值更新 bin1 字符串的第二个字符。

  • 去掉bin1字符串的第一个字符,每次操作字符串大小都会减少1。

示例

输入

bin1 = "0101011"; bin2 = "011";

输出

Yes

说明- 我们可以执行以下操作将 bin1 字符串转换为 bin2 字符串。

  • 我们可以用 min(0,1) 替换第二个字符并删除第一个字符。因此,该字符串变为 001011。

  • 我们再次执行相同的操作,字符串变为01011。

  • 在接下来的几次操作中,字符串分别变为 0011 和 011。

输入

bin1 = "1110"; bin2 = "1110";

输出

Yes

解释 - 给定的字符串已经相同。

输入

bin1 = "101101"; bin2 = "1110";

输出

No

说明 - 我们无法通过执行给定的操作将 bin1 字符串转换为 bin2 字符串。

方法 1

如果 bin1 字符串的长度较小,我们无法将其转换为 bin2 字符串。

在其他情况下,bin1 字符串的最后一个 len2 − 1 字符保持不变,因为我们不对它执行任何操作。因此,两个字符串中的最后 len2 − 1 个字符应该相同。

另外,如果bin2字符串的第一个字符是‘0’,我们应该对bin1字符串的起始字符进行min()操作,并且它应该至少包含一个‘0’。

如果bin2字符串中的第一个字符是‘1’,我们应该对bin2字符串的起始字符进行max()操作,并且它应该至少包含一个‘1’。

算法

步骤 1 - 如果 bin1 的长度小于 bin2 字符串的长度,则返回 false。

步骤 2 - 从第二个位置开始遍历 bin2 字符串。

步骤 3 - 如果 bin2[p] 不等于 bin1[p + len1 - len2],则返回 false,因为最后 len2 -1 个字符不相同。

步骤4 - 遍历第一个len1 - len2 + 1个字符,检查是否包含bin2[0]字符。如果是,则返回true。

第 5 步 - 在函数末尾返回 false。

示例

#include <bits/stdc++.h>
using namespace std;

bool convertAtoB(string bin1, string bin2) {
    int len1 = bin1.size(), len2 = bin2.size();
    // When length 1 is less than length 2
    if (len1 < len2) {
        return false;
    }
    // Check whether substring bin1[p + len1 - len2]... bin1[len1] and bin2[1]... bin2[len2]
    for (int p = 1; p < len2; p++) {
        if (bin1[p + len1 - len2] != bin2[p]) {
            return false;
        }
    }
    // Check whether substring bin1[0... len1 - len2 - 1] contains bin2[0]
    for (int p = 0; p < len1 - len2 + 1; p++) {
        if (bin1[p] == bin2[0]) {
            return true;
        }
    }
    return false;
}
int main() {
    string bin1 = "0101011";
    string bin2 = "011";
    bool res = convertAtoB(bin1, bin2);
    if (res == true) {
        cout << "YES, It is possible to convert bin1 to bin2.";
    } else {
        cout << "NO, It is not possible to convert bin1 to bin2.";
    }
}

输出

YES, It is possible to convert bin1 to bin2.

时间复杂度 - O(N) 来匹配字符串字符。

空间复杂度 - O(1),因为我们不使用任何动态空间。

我们学会了按照给定的操作将第一个二进制字符串转换为第二个二进制字符串。程序员可能会尝试通过用最后一个和最后第二个字符的最小值或最大值替换最后一个字符并删除最后一个字符来检查一个字符串是否可以转换为另一个字符串。

以上是通过重复替换第二位,使二进制字符串相等的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:tutorialspoint。如有侵权,请联系admin@php.cn删除
C和性能:它仍然主导C和性能:它仍然主导May 01, 2025 am 12:14 AM

C 在性能优化方面仍然占据主导地位,因为其低级内存管理和高效执行能力使其在游戏开发、金融交易系统和嵌入式系统中不可或缺。具体表现为:1)在游戏开发中,C 的低级内存管理和高效执行能力使得它成为游戏引擎开发的首选语言;2)在金融交易系统中,C 的性能优势确保了极低的延迟和高吞吐量;3)在嵌入式系统中,C 的低级内存管理和高效执行能力使得它在资源有限的环境中非常受欢迎。

C XML框架:为您选择合适的一个C XML框架:为您选择合适的一个Apr 30, 2025 am 12:01 AM

C XML框架的选择应基于项目需求。1)TinyXML适合资源受限环境,2)pugixml适用于高性能需求,3)Xerces-C 支持复杂的XMLSchema验证,选择时需考虑性能、易用性和许可证。

C#vs. C:为您的项目选择正确的语言C#vs. C:为您的项目选择正确的语言Apr 29, 2025 am 12:51 AM

C#适合需要开发效率和类型安全的项目,而C 适合需要高性能和硬件控制的项目。 1)C#提供垃圾回收和LINQ,适用于企业应用和Windows开发。 2)C 以高性能和底层控制着称,广泛用于游戏和系统编程。

c  怎么进行代码优化c 怎么进行代码优化Apr 28, 2025 pm 10:27 PM

C 代码优化可以通过以下策略实现:1.手动管理内存以优化使用;2.编写符合编译器优化规则的代码;3.选择合适的算法和数据结构;4.使用内联函数减少调用开销;5.应用模板元编程在编译时优化;6.避免不必要的拷贝,使用移动语义和引用参数;7.正确使用const帮助编译器优化;8.选择合适的数据结构,如std::vector。

如何理解C  中的volatile关键字?如何理解C 中的volatile关键字?Apr 28, 2025 pm 10:24 PM

C 中的volatile关键字用于告知编译器变量值可能在代码控制之外被改变,因此不能对其进行优化。1)它常用于读取可能被硬件或中断服务程序修改的变量,如传感器状态。2)volatile不能保证多线程安全,应使用互斥锁或原子操作。3)使用volatile可能导致性能slight下降,但确保程序正确性。

怎样在C  中测量线程性能?怎样在C 中测量线程性能?Apr 28, 2025 pm 10:21 PM

在C 中测量线程性能可以使用标准库中的计时工具、性能分析工具和自定义计时器。1.使用库测量执行时间。2.使用gprof进行性能分析,步骤包括编译时添加-pg选项、运行程序生成gmon.out文件、生成性能报告。3.使用Valgrind的Callgrind模块进行更详细的分析,步骤包括运行程序生成callgrind.out文件、使用kcachegrind查看结果。4.自定义计时器可灵活测量特定代码段的执行时间。这些方法帮助全面了解线程性能,并优化代码。

C  中的chrono库如何使用?C 中的chrono库如何使用?Apr 28, 2025 pm 10:18 PM

使用C 中的chrono库可以让你更加精确地控制时间和时间间隔,让我们来探讨一下这个库的魅力所在吧。C 的chrono库是标准库的一部分,它提供了一种现代化的方式来处理时间和时间间隔。对于那些曾经饱受time.h和ctime折磨的程序员来说,chrono无疑是一个福音。它不仅提高了代码的可读性和可维护性,还提供了更高的精度和灵活性。让我们从基础开始,chrono库主要包括以下几个关键组件:std::chrono::system_clock:表示系统时钟,用于获取当前时间。std::chron

C  中的实时操作系统编程是什么?C 中的实时操作系统编程是什么?Apr 28, 2025 pm 10:15 PM

C 在实时操作系统(RTOS)编程中表现出色,提供了高效的执行效率和精确的时间管理。1)C 通过直接操作硬件资源和高效的内存管理满足RTOS的需求。2)利用面向对象特性,C 可以设计灵活的任务调度系统。3)C 支持高效的中断处理,但需避免动态内存分配和异常处理以保证实时性。4)模板编程和内联函数有助于性能优化。5)实际应用中,C 可用于实现高效的日志系统。

See all articles

热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

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

热工具

禅工作室 13.0.1

禅工作室 13.0.1

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

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器