409. 最长回文串

小豆丁 1年前 ⋅ 1049 阅读
409. 最长回文串
给定一个包含大写字母和小写字母的字符串,找到通过这些字母构造成的最长的回文串。

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

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

示例 1:

输入:
"abccccdd"

输出:
7

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

解析

直接用set,然后判断是否剩下字符

class Solution {
    public int longestPalindrome(String s) {
        Set<Character> set = new HashSet<>();
        int len = 0;
        for(char val:s.toCharArray()){
            if(set.contains(val)){
                len +=2;
                set.remove(val);
            }else{
                set.add(val);
            }
        }
        return set.size()>0?(len+1):len;

    }

}