题解 | #密码截取#

https://www.nowcoder.com/practice/3cd4621963e8454594f00199f4536bb1

s= input()
out = 0 #通过全局变量out保留最长字符串的长度

for i in range(0, len(s)):  # 双指针,遍历每一个字符。
    k = i - 1
    j = i + 1
    len_ABA = 1
    while k >= 0 and j < len(s):
        if s[k] == s[j]: #如果前一位和后一位相同,则通过while局部深度循环,直到获得最大的前i位和后i位相同的字符串长度
            k -= 1
            j += 1
            len_ABA += 2
        else:
            break

    k = i
    j = i + 1
    len_ABBA = 0
    while k >= 0 and j < len(s):
        if s[k] == s[j]: #如果前一位和后一位相同,则通过while局部深度循环,直到获得最大的前i位和后i位相同的字符串
            k -= 1
            j += 1
            len_ABBA += 2
        else:
            break

    now_len = max(len_ABA, len_ABBA)
    if out <now_len: #如果局部获得的字符串长度长于之前获得的out,则刷新该全局变量。
        out = now_len
print(out)
全部评论

相关推荐

01-07 11:46
Java
如图:也是让我遇到逆天公司了,实习生是按天给工资,不忙直接强制休假了
baskly:公司为北京超图软件股份有限公司武汉分公司,明年公司应该会招新实习生,刷到的小伙伴快跑
点赞 评论 收藏
分享
king327:要从现有项目中挖掘1-2个你解决过的具体技术难题 详细描述你的解决方案、技术选型理由和最终效果 这比罗列更多基础功能更有说服力
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务