题目描述
给定一个包含大写字母和小写字母的字符串,找到通过这些字母构造成的最长的回文串。
在构造过程中,请注意区分大小写。比如 "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;
}
}