题解 | #密码截取#

密码截取

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

package main
import "fmt"

func main() {
    var s string
    for {
        _, err := fmt.Scan(&s)
        if err != nil {
            break
        }
        fmt.Println(longestPalindrome(s))
    }
    
    
}

func longestPalindrome(s string) int {
    dp := make([][]int, len(s))
    for i := 0; i < len(s); i++ {
        dp[i] = make([]int, len(s))
        dp[i][i] = 1
    }
    //初始化
    max := 1
    for i := len(s)-2; i >= 0;i-- {
        for j := i+1; j < len(s); j++ {
            if s[i]==s[j] {
                if dp[i+1][j-1]==1 {
                    dp[i][j]=1
                } else if j - i <= 1 {
                    dp[i][j] = 1
                }
                if dp[i][j]== 1 && max < j-i+1{
                    max = j-i+1
                }
            }
        }
    }
    return max
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
06-25 17:22
点赞 评论 收藏
分享
06-27 15:15
长安大学 Java
哈哈哈,你是老六:这种就是培训机构骗钱的
点赞 评论 收藏
分享
05-29 09:02
门头沟学院 Java
点赞 评论 收藏
分享
湫湫湫不会java:先投着吧,大概率找不到实习,没实习的时候再加个项目,然后把个人评价和荣誉奖项删了,赶紧成为八股战神吧,没实习没学历,秋招机会估计不多,把握机会。或者说秋招时间去冲实习,春招冲offer,但是压力会比较大
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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