#include<bits/stdc++.h>
using namespace std;
static constexpr int AwA = 1e5 + 10;
static constexpr int PwP = 6e5 + 10;
int n;
//因为这道题每个字符串长度不确定,所以我只能抛弃我的char数组了(悲)
string s[AwA];
//记录每个节点算出来的父亲
int fa[AwA];
//字典树,id[u]!=0时记录该节点对应的字符串编号
int ch[PwP][26], id[PwP], tot = 1;
vector<int> tr[AwA];
int sz[AwA];
long long ans;
//贪心选点
void Dfs(int u) {
int cur = 1;
for (int v: tr[u]) {
Dfs(v);
ans += cur;
cur += sz[v];
}
}
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr), cout.tie(nullptr);
cin >> n;
for (int i = 1; i <= n; i++) cin >> s[i];
//根据字符串长度排序
sort(s + 1, s + n + 1, [](auto &s1, auto &s2) { return s1.size() < s2.size(); });
int u, p;
for (int i = 1; i <= n; i++) {
//如果路径上没有终止节点,即没有后缀,则父亲为虚根0
fa[i]=0;
u = 1;
//倒叙枚举,变后缀为前缀
for (auto k = s[i].rbegin(); k != s[i].rend(); k++) {
p = *k - 'a';
if (!ch[u][p]) ch[u][p] = ++tot;
u = ch[u][p];
//遇到终止节点更新父亲
if (id[u]) fa[i] = id[u];
}
//记录终止节点
id[u] = i;
}
//因为父亲串的长度一定小于儿子,所以根据字符串长度排序后为拓扑逆序
for (int i = n; i; i--) sz[i]++, sz[fa[i]] += sz[i];
//建树
for (int i = 1; i <= n; i++) tr[fa[i]].push_back(i);
//按子树大小排序,方便贪心选择
//注意0节点也要排序
auto cmp = [&](int i, int j) { return sz[i] < sz[j]; };
for (int i = 0; i <= n; i++) sort(tr[i].begin(), tr[i].end(), cmp);
Dfs(0);
printf("%lld\n", ans);
return 0;
}