判断一个字符串S是否由其他两个字符串A, B混合而成

算法题:判断一个字符串S是否由其他两个字符串A, B混合而成。(混合时字符顺序不变)

例如:
A: "chdkeold"
B: "jgkhqp"
S: "chdjkgkheqopld"
输出: True

A: "aebc"
B: "axbd"
S: "axaebdbc"
输出: True

(做了一道算法题,以为很简单,结果花了大约4个小时,真是不敢相信自己这么笨。。。)结果如下:

def is_mixed(a, b, s):
    if len(a) + len(b) != len(s):
        return False 
    if len(a) == 0:
        return s == b 
    elif len(b) == 0:
        return s == a 
    else:
        out = False
        if a[0] == s[0]:
            out = is_mixed(a[1:], b, s[1:])
        if b[0] == s[0]:
            out = out or is_mixed(a, b[1:], s[1:])
        return out 

原题链接

posted @   成民  阅读(868)  评论(0编辑  收藏  举报
编辑推荐:
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
阅读排行:
· 不到万不得已,千万不要去外包
· C# WebAPI 插件热插拔(持续更新中)
· 会议真的有必要吗?我们产品开发9年了,但从来没开过会
· 如何打造一个高并发系统?
· 【译】我们最喜欢的2024年的 Visual Studio 新功能
点击右上角即可分享
微信分享提示