解题思路: 题目举例违禁词的时候说的是 "love"和"Love" ,于是我以为是仅仅是首字母的大小写而已,然后就这样连续修改,提交,错了10几次(心疼),也懊恼了好几个小时,我一直以为是中间处理出现了的问题,不停在改,正当快要奔溃之际,突然想到了很多关于 ”爱“ 的单词:”LOVE,LoVE,LOve,LovE......“
是的,就是它们,这些 ”不常规“ 的 ”爱“ ,处理起来呢,也很简单,将需要检查的单词全部转化为大写(或小写),再判断即可,只是一般很难想到这种情况而已,但要注意保存初始输入的单词,特别是首字母的大小写,毕竟违禁词也有 ”出头之日“ ,然后根据判断结果逐一构造输出答案(result)就OK了,后面没有标点的单词(check()函数的第二个参数fun==0来标记)记得加空格,有标点的单词 (check()函数的第二个参数fun==1来标记) 就不用我们画蛇添足加空格了。
注意事项: 还有一个需要注意的是,"sky,land,sea"这种情况(空格无法分离),空格只能分离到这一步,剩下的需要自己去进一步分离。
参考代码:
#include <iostream> #include <algorithm> #include <string> #include <sstream> using namespace std; int flags,punctuation,n; string str,tem,tem1,tem2,result="",words[10005],w; string dirtywords[1005]; void check(string ww,int fun)//传过来的单词(ww)必须分离干净,不要带标点,该函数判断是否违禁并构造最终结果,所以相关变量要放到全局 { flags=0;//默认不违禁(敏感),如判断违禁标记为 1 tem1=ww; //暂时存储初始输入并分离后的单词(这样传过来的单词就可以用来转化判断啦)//记住它以前的模样 transform(ww.begin(),ww.end(),ww.begin(),::tolower);//统一转化为小写判断 for(int i=0;i<n;i++) { if(dirtywords[i]==ww)//如果是敏感词汇 { flags=1;//敏感标记 for(int j=0;j<tem1.size();j++) { if(j==0) result+=tem1[0];//首字母保留(记住是以前输入的首字母,而不是转化后的) else result+='*';//余下添加'*' } if(fun==0) result+=" ";//'没有标点的单词后补空格' } } if(flags==0)//非敏感标记,正常相加 { result+=tem1; if(fun==0) result+=" ";//'没有标点的单词后补空格' } } int main() { cin>>n; for(int i=0;i<n;i++) cin>>dirtywords[i]; for(int i=0;i<n;i++) { tem=dirtywords[i]; transform(tem.begin(),tem.end(),tem.begin(),::tolower);//统一转化为小写判断 dirtywords[i]=tem;//存入敏感词数组 } getchar();//读取cin留下的回车符 while(getline(cin,str)) { istringstream ss(str); while(ss>>w)//以空格分离单词 { flags=0; punctuation=0; for(int i=0;i<w.size();i++)///对于"sky,land,sea"这种情况进一步分离单词 (空格无法分离) { if((w[i]<'A'||w[i]>'Z')&&(w[i]<'a'||w[i]>'z'))//以空格分离后的单词存在有标点的情况 { punctuation=1;//标点标记 } } if(punctuation==0)//没有标点的单个单词(正常单词) { check(w,0); } if(punctuation==1)//有标点的多个单词 { int start=0; tem2=""; { for(int i=0;i<w.size();i++) { if((w[i]>='A'&&w[i]<='Z')||(w[i]>='a'&&w[i]<='z'))//遇到字母逐一保存 { words[start]=w[i]; start++; } else if((w[i]<'A'||w[i]>'Z')&&(w[i]<'a'||w[i]>'z'))//遇到标点暂时终止 { for(int j=0;j<start;j++) { tem2+=words[j];//收集之前统计的字母 } check(tem2,1);//收集好后传过去 tem2="";//清空以便重新保存单词 start=0;//遇到标点,重新统计单词 result+=w[i];//最后记得加上标点 } } } //"sky,land,sea" 特殊的 "sea" 后面没有标点 (当做正常单词处理) for(int j=0;j<start;j++) tem2+=words[j]; check(tem2,0); } } cout<<result<<endl;//输出结果 result=""; //清空结果,为下一次输入做准备 } return 0; }//dongdong
0.0分
2 人评分
C语言程序设计教程(第三版)课后习题6.8 (C++代码)浏览:614 |
文科生的悲哀 (C语言代码)浏览:1538 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:561 |
1128题解(返回值为数组的情况)浏览:571 |
DNA (C语言代码)浏览:837 |
C语言程序设计教程(第三版)课后习题11.3 (C语言代码)浏览:661 |
C语言训练-8除不尽的数 (C语言代码)浏览:1469 |
小O的图案 (C语言代码)浏览:979 |
小O的数字 (C语言代码)浏览:1490 |
A+B for Input-Output Practice (IV) (C语言代码)浏览:489 |