码迷,mamicode.com
首页 > 编程语言 > 详细

Educational Codeforces Round 48 (Rated for Div. 2) B. Segment Occurrences(数组前缀和防TLE)

时间:2018-08-04 11:40:07      阅读:146      评论:0      收藏:0      [点我收藏+]

标签:div   存在   数组   string   i++   clu   相减   字符串   一个   

题目链接:http://codeforces.com/contest/1016/problem/B

给两个字符串s,t,之后给出s的一个区间,问这个子串中存在多少个子串与t相同

如果一个一个查找就会超时,因此只需要把前缀和相减即可

#include <bits/stdc++.h>

using namespace std;


int n,m,q;
string s,t;
int l,r;
int hay[10000],shay[10000];

int main()
{
    ios::sync_with_stdio(false);
    cin>>n>>m>>q;
    cin>>s>>t;
    s=" "+s;
    t=" "+t;
    for(int i=1;i<=n-m+1;i++)
    {
        hay[i]=1;
        for(int j=0;j<m;j++)
        {
            if(s[i+j]!=t[1+j])
            {
                hay[i]=0;
                break;
            }
        }
        shay[i]=shay[i-1]+hay[i];
    }

    while(q--)
    {
        cin>>l>>r;
        r=r-m+1;
        if(r<l) cout<<"0"<<endl;
        else cout<<shay[r]-shay[l-1]<<endl;
    }
    return 0;
}

 

Educational Codeforces Round 48 (Rated for Div. 2) B. Segment Occurrences(数组前缀和防TLE)

标签:div   存在   数组   string   i++   clu   相减   字符串   一个   

原文地址:https://www.cnblogs.com/Fy1999/p/9417082.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!