Python算法题

判断一个字符串S是否由其他两个字符串A, B混合而成。(混合时字符顺序不变)
即A,B随机切分之后的子串,随机混合在一起成为S,但是子串在S中的相对顺序要跟在原来在A,B中的顺序保持一致。
如果S是由A,B混合而成,输出True。否则,输出False

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

A: “aebc”
B: “axbd”
S: “axaebdbc”
输出: True

A: “aac”
B: “bba”
S: “aabcab”
输出:False

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:
        result = False
        if a[0] == s[0]:
            result = is_mixed(a[1:], b, s[1:])
        if b[0] == s[0]:
            result = is_mixed(a, b[1:], s[1:])
        return result
        
res = is_mixed("aac", "bba", "aabcab")
# res = is_mixed("aebc", "axbd", "axaebdbc")
print(res)
### Python 算法题练习资源与平台 对于希望提升Python编程技能以及解决算法问题的学习者来说,存在多个优质的在线资源和平台可供利用。这些平台不仅提供丰富的题目库,还支持实时编码环境,允许用户提交解决方案并获得即时反馈。 #### LeetCode LeetCode是一个非常受欢迎的选择之一,它拥有大量的面试真题覆盖广泛的主题,包括但不限于数组、链表、字符串处理等。每道题目都配有详细的解析说明,帮助学习者理解解题思路[^1]。 #### HackerRank HackerRank提供了多样化的挑战赛和个人长路径规划功能,特别适合那些希望通过竞赛形式提高自己能力的人士。这里同样有大量的Python相关题目等待探索,并且社区活跃度高,能够及时获取他人分享的经验和技术文章。 #### Codeforces 和 AtCoder 这两个网站定期举办全球性的编程比赛,在比赛中可以遇到各种难度级别的逻辑思维训练题。虽然主要面向竞技型选手设计,但对于想要深入研究算法的人来说也是非常好的实践场所。 ```python def factorial(n): """实现一个递归函数来计算给定正整数n的阶乘""" if n == 0 or n == 1: return 1 else: return n * factorial(n - 1) print(factorial(5)) # 输出应为120 ``` 除了上述提到的专业站点外,还有许多其他途径可以获得关于Python算法的知识补充: - **书籍**: 如《Python Cookbook》或《Algorithm Design Manual》,它们包含了大量实用的例子; - **视频教程**: YouTube上有很多高质量的教学频道专注于讲解计算机科学基础概念及其应用实例; - **博客论坛**: Stack Overflow, Reddit上的r/learnprogramming板块都是交流心得的好地方;
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值