#include <iostream>
#include<bits/stdc++.h>
using namespace std;
int main() {
string str;
while (cin >> str) { // 注意 while 处理多个 case
map<string,int> count;
int lengt=str.size();
for(int i=0;i<lengt;i++)
for(int j=i;j<lengt;j++)
{
string st=str.substr(i,j-i+1);
count[st]++;
}
for(auto it=count.begin();it!=count.end();it++)
{ if(it->second>1)
cout<<it->first<<" "<<it->second<<endl;
}
}
}
// 64 位输出请用 printf("%lld")
很好的用map处理字串的思路
for(int i=0;i<lengt;i++)
for(int j=i;j<lengt;j++)
{
string st=str.substr(i,j-i+1);
count[st]++;
}

京公网安备 11010502036488号