leetcode_字符串 459. 重复的子字符串

459. 重复的子字符串

  • 给定一个非空的字符串s,检查是否可以通过由他的一个子串重复多次构成
  • 思路:
    1. 首先判断字符串s是否为空或长度是否为1,若满足这两种条件,则说明不存在子字符串,返回False
    2. 遍历所有可能的子串(从长度为1的子串开始遍历)
    3. 如果存在子串a使得len(s)能够整除len(a),则说明该子串a有可能重复多次后能够成为s
    4. 将子串a重复多次直至和字符串s等长,判断是否相等,相等返回True,否则返回False
bash 复制代码
def func(s):
    if not s or len(s) == 1:
        # 若字符串为空,返回False
        return False
        
    for i in range(1, len(s)):
        # 遍历所有可能的子串长度
        if len(s) % i == 0:
            # 如果 s 的长度可以被 i 整除
            a = s[:i]
            # 从字符串 s 中提取长度为 i 的子串
            if a * (len(s) // i) == s:
                # 不断重复子串a直到长度为len(s)
                return True
    return False
        

print(func("abab"))
  • 时间复杂度: O(n^2),其中n为字符串s的长度
    • 最坏的情况下,当 i 接近 n 时,子串提取操作需要 O(n),并且比较操作也是 O(n),总的时间复杂度为O(n^2)
  • 空间复杂度: O(n)
相关推荐
Purple Coder6 小时前
基于DGN的电工基础-8
职场和发展
QiLinkOS7 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
疯狂打码的少年7 小时前
【操作系统】页面置换算法(OPT/FIFO/LRU)
算法
Waay8 小时前
面试口述版:个人对 Prometheus 完整理解
运维·学习·云原生·面试·职场和发展·kubernetes·prometheus
小O的算法实验室8 小时前
2026年CIE,优化客货协同运输:综合地铁系统的列车容量动态分配
算法
Coder_Shenshen8 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
硕风和炜9 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
我是一颗柠檬10 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农10 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
凯瑟琳.奥古斯特11 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展