#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=1000010;
int n;
int tr[N][26],f[N],idx;
int q[N],ne[N];
char str[N];
int id[210];
void insert(int x){
int p=0;
for(int i=0;str[i];i++){
int t=str[i]-'a';
if(!tr[p][t]) tr[p][t]=++idx;
p=tr[p][t];
f[p]++;
}
id[x]=p;
}
void build(){
int hh=0,tt=-1;
for(int i=0;i<26;i++)
if(tr[0][i])
q[++tt]=tr[0][i];
while(hh<=tt){
int t=q[hh++];
for(int i=0;i<26;i++){
int &p=tr[t][i];
if(!p) p=tr[ne[t]][i];
else{
ne[p]=tr[ne[t]][i];
q[++tt]=p;
}
}
}
}
int main(){
scanf("%d",&n);
for(int i=0;i<n;i++){
scanf("%s",str);
insert(i);
}
build();
for(int i=idx-1;i>=0;i--) f[ne[q[i]]]+=f[q[i]];
for(int i=0;i<n;i++) printf("%d\n",f[id[i]]);
return 0;
}
低价批发课程+QQ2213261943
低价批发课程+QQ2213261943