解题思路:进行字符串的读入,在通过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 人评分
C语言程序设计教程(第三版)课后习题8.7 (C语言代码)浏览:468 |
C语言训练-阶乘和数* (C语言代码)浏览:997 |
C语言程序设计教程(第三版)课后习题11.12 (C语言代码)浏览:726 |
校门外的树 (C语言代码)浏览:1124 |
C语言训练-排序问题<1> (C语言代码)浏览:1351 |
K-进制数 (C++代码)浏览:858 |
C语言程序设计教程(第三版)课后习题10.5 (C语言代码)浏览:733 |
C语言考试练习题_一元二次方程 (C语言代码)浏览:737 |
时间转换 (Java代码)浏览:575 |
C语言训练-角谷猜想 (C语言代码)浏览:1708 |