数组不要开小哦
#include<iostream>
#include<cstdio>
#include<string>
#include<cmath>
#include<algorithm>
#define maxn 2050
using namespace std;
int n,t;
string s[maxn];
bool cmp(string s1, string s2)
{
return s1<s2;
}
struct Node
{
string name;
int sum;
}node[maxn];
int main()
{
cin>>n;t=0;
getchar();
for(int i=0;i<n;i++)
getline(cin,s[i]);
sort(s,s+n,cmp);
for(int i=0;i<n;i++)
{
string ss="";
int len=s[i].length();
for(int j=0;j<len;j++)
{
if(s[i][j]!=' ')ss+=s[i][j];
else break;
}
int j;
for(j=0;j<t;j++)
if(node[j].name==ss){node[j].sum++;break;}
if(j>=t){node[t].name=ss;node[t].sum=1;t++;}
}
for(int i=0;i<t;i++)
{
cout<<node[i].name<<" "<<node[i].sum<<endl;
}
return 0;
}