#4867. 统计不同回文子序列

统计不同回文子序列

题目描述

给你一个字符串 ss ,返回 ss 中不同的非空回文子序列个数。由于答案可能很大,请输出对 109+710^9 + 7 取余 的结果。

字符串的子序列可以经由字符串删除 0 个或多个字符获得。

如果一个序列与它反转后的序列一致,那么它是回文序列。

如果存在某个 ii , 满足 ai !=biai != bi_ ,则两个序列 a1,a2,...a1, a2, ... 和 b1,b2,...b1, b2, ... 不同。

输入格式

一行一个字符串 ss

输出格式

一行一个整数表示答案。

示例 1:

bccb
6

解释: 6 个不同的非空回文子字符序列分别为:'b', 'c', 'bb', 'cc', 'bcb', 'bccb'。

注意:'bcb' 虽然出现两次但仅计数一次。

示例 2:

abcdabcdabcdabcdabcdabcdabcdabcddcbadcbadcbadcbadcbadcbadcbadcba
104860361

解释: 共有 3104860382 个不同的非空回文子序列,104860361 是对 109+710^9 + 7 取余后的值。

提示:

  • 1<=s.length<=10001 <= s.length <= 1000
  • s[i]s[i] 仅包含 a'a'b'b'c'c' 或 d'd'

SOURCE

统计不同回文子序列