ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

P1308 [NOIP2011 普及组] 统计单词数[普及-]

2022-07-06 14:06:51  阅读:132  来源: 互联网

标签:lenb 普及 word NOIP2011 int 单词 ans sen P1308


https://www.luogu.com.cn/problem/P1308
涉及知识点:模拟,字符串
橙色题
思路?在代码里
#include<bits/stdc++.h>
using namespace std;
string word,sen;
int ans,j,ans1;
int main()
{
    getline(cin,word); //先输入两个字符串 
    getline(cin,sen);
    int lena=word.size(); //求长度 
    int lenb=sen.size();
    for(int i=0; i<lena; i++) word[i]=toupper(word[i]); //转换为大写 
    for(int i=0; i<lenb; i++) sen[i]=toupper(sen[i]);
    for(int i=0; i<=lenb-lena; i++) //sen串-word串的长度 ,枚举每一个字符
    {                               //因为只需在sen串中找到首字母即可,所以为节省时间减去word串的长度 
        for(j=0; j<lenb; j++) //枚举word串的每一个字符,继续判断首字母之后的字母是否相等 
        {
            if(sen[i+j]!=word[j])  break; //两种不可行的情况,直接退出word串的循环,换下一个字符 
            if(i>0&&sen[i-1]!=' ') break;
        }
        //注意:上面j结束循环时多加了一次1 
        if(j==lena&&(sen[i+j]==' '||i+j==lenb)) //如果在上一个循环中没有中途退出且(sen[i+j]也就是该单词后面是空格
        //或单词的结尾正好在sen串边界
        {
            ans++;
            if(ans==1) ans1=i;
        }
    }
    if(ans==0) cout<<"-1";
    else cout<<ans<<" "<<ans1; //输出结果 
    return 0;
}

 

 

标签:lenb,普及,word,NOIP2011,int,单词,ans,sen,P1308
来源: https://www.cnblogs.com/2elaina/p/16450523.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有