题解 | #最长回文子串#

最长回文子串

https://www.nowcoder.com/practice/b4525d1d84934cf280439aeecc36f4af

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param A string字符串 
 * @return int整型
 */
int getLongestPalindrome(char* A ) {
    // write code here
    int len = strlen(A);
    if(len < 2) return len;
    int* dp = (int*)malloc(sizeof(int) * len);
    int max = 1;
    for(int i = 0; i < len; i++) {
        if(i + 1 < len && A[i] == A[i + 1]) {
            int j = i + 1;
            int count = 0;
            int left = i;
            while(left >= 0 && j < len && A[left] == A[j]) {
                count++;
                j++;
                left--;
            }
            if(count * 2 > max) max = count * 2;
        }
        if(i + 2 < len && A[i] == A[i + 2]) {
            int j = i + 2;
            int count = 0;
            int left = i;
            while(left >= 0 && j < len && A[left] == A[j]) {
                count++;
                j++;
                left--;
            }
            if(count * 2 + 1 > max) max = count * 2 + 1; 
        }
        if(max / 2 > len - i) break;
    }

    return max;
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-04 18:02
好不容易拿到了字节Offer,鼠鼠做后端的,但家里人觉得可能被裁员不稳定,让鼠鼠去投国企,现在好纠结到底该咋选
文档传偷助手:该投就投吧,不过建议别放弃offer 拿到手里的才是最好的
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
_mos_:我以为手抄报简历就已经很顶了,没想到还有表格简历
点赞 评论 收藏
分享
Rena1ssanc...:对的,要是面评没太烂,勤更新简历等捞就行了,腾讯可以无限复活
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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