解题思路:  题目举例违禁词的时候说的是 "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.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论