【Java】最长回文串

题目描述

给定一个包含大写字母和小写字母的字符串,找到通过这些字母构造成的最长的回文串。

在构造过程中,请注意区分大小写。比如 "Aa" 不能当做一个回文字符串。

注意:
假设字符串的长度不会超过 1010。

示例 1:

输入:
"abccccdd"

输出:
7

解释:
我们可以构造的最长的回文串是"dccaccd", 它的长度是 7。

1、这道题不需要你给出具体的回文串构造,只要长度

2、遍历一次记录每个字符出现的次数

3、如果次数全部是偶数,那么简单,把次数除以2,再一个个累加起来

4、如果出现了奇数,那么把这个字符作为回文串的中心,此时算出的长度因为取整的缘故,一定是偶数,再加1即可

5、此时记录的长度一定是奇数了,表示已经有一个字符作为回文串的中心了,再出现奇数个的字符也只能减一除以二,用它的偶数个

class Solution {
    public int longestPalindrome(String s) {
        HashMap<Character,Integer> map = new HashMap<>();
        for(char c:s.toCharArray()){
            map.put(c,map.getOrDefault(c, 0) + 1);
        }
        int ans = 0;
        for(Integer v:map.values()){
            ans += v /2 * 2;
            if(v % 2 == 1 && ans % 2 == 0){
                ans++;
            }
        }
        return ans;
    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章