解题思路:进行字符串的读入,在通过erase和find函数去除符号,在通过流来进行输入和输出,因为map容器会根据key来进行排序,所以用vector来储存顺序
注意事项:
参考代码:
#include<bits/stdc++.h>
using namespace std;
int main(){
string n;
getline(cin,n);
getchar();
vector<string>val;
map<string,int>map1;
int i=n.find('.');
while(i!=-1){
n.erase(n.begin()+i);
i=n.find('.',i+1);
}
i=n.find(',');
while(i!=-1){
n.erase(n.begin()+i);
i=n.find(',',i+1);
}
transform(n.begin(),n.end(),n.begin(),::toupper);
stringstream ss;
ss<<n;
string n2;
int maxn=0;
while(ss>>n2){
int len=n2.size();
maxn=max(maxn,len);
map1[n2]++;
vector<string>::iterator it=find(val.begin(),val.end(),n2);
if(it==val.end())
val.push_back(n2);
}
int len1=val.size();
for(int i=0;i<len1;i++){
cout<<setiosflags(ios::right)<<setw(maxn)<<val[i];
cout<<":";
for(int j=0;j<map1[val[i]];j++)
cout<<"*";
cout<<map1[val[i]]<<endl;
}
}
0.0分
0 人评分