10
24
2015
0

[Codeforces Round #320] LCS Again


F. LCS Again
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

You are given a string S of length n with each character being one of the first m lowercase English letters.

Calculate how many different strings T of length n composed from the first m lowercase English letters exist such that the length of LCS (longest common subsequence) between S and T is n - 1.

Recall that LCS of two strings S and T is the longest string C such that C both in S and T as a subsequence.

Input

The first line contains two numbers n and m denoting the length of string S and number of first English lowercase characters forming the character set for strings (1 ≤ n ≤ 100 0002 ≤ m ≤ 26).

The second line contains string S.

Output

Print the only line containing the answer.

Sample test(s)
input
3 3
aaa
output
6
input
3 3
aab
output
11
input
1 2
a
output
1
input
10 9
abacadefgh
output
789
Note

For the first sample, the 6 possible strings T are: aabaacabaacabaacaa.

For the second sample, the 11 possible strings T are: aaaaacabaabbabcacaacbbaababcaa,cab.

For the third sample, the only possible string T is b.

题目大意:字符集大小为m,给出一个长度为n字符串S,问有多少个长度为n的字符串T,使得S和T的LCS长度为n-1。


标准做法是DP套DP的状压DP,然而太烦了不想写。在官方题解的讨论里找到了一个简单很多的非DP做法,不想翻译了自己看吧。

I think there's a simpler solution to 1D without DP (the hard part is verifying that it's valid, I suppose, but this follows from a small bit of case analysis).
We want the number of strings other than S which can result from removing one character and adding one. First, we block the string S into groups of consecutive equal characters. Removing a character from any part of one group is equivalent, so if there are k groups, we consider each of these k possibilities. Suppose we've taken from a group with size g and character c; you can add back any color in any place, except you can't add back c adjacent to any of the g - 1 remaining c's in the group (or you would get S back). Also, for each other group with size h and color d, we overcount the number of ways to add another d into this group by h, so the total number of valid distinct ways to add a character to S with one of the k groups diminished is nm - n (since n is the sum of the sizes of all of the groups).
So our total answer would be k(mn - n), except a few of the strings T are double counted. It turns out that the only way to double count T is if there is some substring ab...aba in S (alternating different letters of some length  ≥ 2) which becomes replaced by ba...bab (see if you can see the two ways to make this transformation). Thus the final answer is
k(mn-n)-Number of alternating substrings of length at least 2
which runs in O(n) pretty easily.

代码在此。

Category: 题解 | Tags: Codeforces DP | Read Count: 544

登录 *


loading captcha image...
(输入验证码)
or Ctrl+Enter

Host by is-Programmer.com | Power by Chito 1.3.3 beta | Theme: Aeros 2.0 by TheBuckmaker.com