数学规律题,很容易计算的。以初始测试数据3为例。
Str Y I S V O W E L
--------------------------
Len 1 2 3 4 | 5 6 7 8
Y + | +
I + + | + +
S
V
O + + + + | + + + +
W
E + | +
L
首先注意1-4与5-8是对称的(仅长度不同)。长度为2的总数可以在长度为1的总数的基础上累加计算(因为2-len-1的字符若为Vow则各递增1),长度为3的可以在长度为2的基础上累加计算。
故,首先求得cnt[]数组表示从1开始到位置n的Vow字符数目。然后遍历1-len/2的长度,求得结果,若len为奇数,则单独再计算一次(len+1)/2。
其实就是递推规律题目,O(n)时间复杂度。
1 /* 509E */ 2 #include 3 #include 4 #include