力扣小白刷题之409题最长回文串

题目描述

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

思路

参考自:https://leetcode-cn.com/problems/longest-palindrome/solution/javade-2chong-shi-xian-fang-fa-by-sweetiee/

使用长度为 58 的整型数组来统计每个字符出现的个数:

  • 每个字符有偶数个可以用来构成回文字符串;
  • 因为回文字符串最中间的那个字符可以单独出现, 所以如果有单独的字符就把它放到最中间。

代码

在这里插入图片描述

偶数的二进制末尾为 0, &1 的话结果为 0;
奇数的二进制末尾为 1,&1 的话结果为 1。

长度为 58 的数组的由来:(26个大写字母)+ (26个小写字母)+ (ASCII表中,大写字母 Z 和小写字母 a 之间有 6 个特殊字符) = 58.

A 65
Z 90
a 97

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值