[HUSTFC 2023] 基因编辑
题目描述
绮月有 $n$ 条 DNA 碱基序列 $S_1,S_2,\dots S_n$,每条碱基序列可以用一个仅包含 `A`、`C`、`G` 和 `T` 这四种大写字母的字符串表示。
绮月可以拼合两条 DNA 碱基序列,具体操作为将前一条碱基序列的一个前缀(可以为空)和后一条的一个后缀(可以为空)结合,如 `ACGC` 与 `CTAT` 拼合就有可能得到 `ACGCTAT`、`ACGCCTAT`、`ACAT` 或 `T`。
绮月据此定义,一个三元组 $(i,j,k)$ 是好的,当且仅当 $1\le i,j,k \le n$,$i\ne k$,$j \ne k$,且 $S_i$ 与 $S_j$ 拼合可以得到 $S_k$。
绮月想知道好的三元组的数量。
输入输出格式
输入格式
第一行包含一个整数 $n\ (3\le n\le 2\times 10^5)$,表示碱基序列的数量。
接下来 $n$ 行,每行包含一个字符串,其中第 $i$ 个字符串定义为碱基序列 $S_i\ (1\le |S_i|\le 2\times 10^6)$。保证 $\sum |S_i| \le 2 \times 10^6$。
输出格式
输出一个整数,表示好的三元组的数量。
输入输出样例
输入样例 #1
3
AAA
AA
AA
输出样例 #1
12
输入样例 #2
3
ACGC
CTAT
ACAT
输出样例 #2
1
输入样例 #3
4
A
C
T
G
输出样例 #3
0