CSES - Required Substring | Xâu con bắt buộc

Xem PDF



Tác giả:
Dạng bài
Điểm: 1900 (p) Thời gian: 1.0s Bộ nhớ: 512M Input: bàn phím Output: màn hình

Nhiệm vụ của bạn là tính toán số lượng xâu độ dài \(n\) có một từ khóa độ dài \(m\) được cho xuất hiện như xâu con của chúng. Tất cả các xâu bao gồm các kí tự A-Z.

Input

  • Dòng đầu vào đầu tiên có một số nguyên \(n\): độ dài của xâu đáp án.
  • Dòng thứ hai có từ khóa độ dài \(m\).

Output

  • In số lượng xâu chia lấy dư cho \(10 ^ 9 + 7\).

Constraints

  • \(1 \leq n \leq 1000\)
  • \(1 \leq m \leq 100\)

Example

Test 1

Input

6
ABCDB

Output

52

Note

Xâu đáp án sẽ có dạng ABCDB\(x\) hoặc \(x\)ABCDB trong đó \(x\) là bất kỳ ký tự nào giữa A-Z.


Bình luận

  • anhduc11092014 10:59 a.m. 18 Tháng 7, 2024

    C++ 100 % AC:

    include<bits/stdc++.h>

    using namespace std;

    template<typename... T>

    define error(args...)

    void err(istream_iterator<string> it) {}
    template<typename T, typename... Args>
    void err(istream_iterator<string> it, T a, Args... args) {cerr << *it << "=" << a << ", "; err(++it, args...);}

    define int long long

    define ff first

    define ss second

    define endl '\n'

    const long long inf = 1LL<<60; //1.5e18
    const int md = 1000000007;

    int dp[1005][105];
    int exp(int x, unsigned int y, int p){
    int res=1; x=x%p;
    while(y>0){
    if (y&1) res= (resx)%p; y=y>>1; x=(xx)%p;
    }
    return res;
    }
    void solve(){
    int n; cin>>n;
    string s; cin>>s;
    int m = s.size();
    //dp[i][j] = no of strings of length i which do not contain s
    // and whose suffix of length j is equal to the prefix of s
    //
    //Let's add one character to each prefix of s and determine the max length
    //of suffix which is also a prefix of s formed by the addition of each character
    int len[m][26];
    for (int i = 0; i < m; i++) {
    for (int j = 0; j < 26; j++) {
    string pre = s.substr(0,i);
    pre += j+'A';
    len[i][j] = 0;
    for (int k = 0; k < pre.size(); k++) {
    if (pre.substr(k) == s.substr(0,pre.size() - k)) {
    len[i][j] = pre.size() - k;
    break;
    }
    }
    }
    }
    dp[0][0] = 1;
    for (int i = 1; i <=n; i++) {
    for (int j = 0; j < m; j++) {
    for (int k = 0; k < 26; k++) {
    (dp[i][len[j][k]] += dp[i-1][j])%=md;
    }
    }
    }
    int ans = exp(26,n,md);
    for (int i = 0; i < m; i++) {
    ans = (ans - dp[n][i] + md) % md;
    }
    cout<<ans; } <br />signed main(){ ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0); #ifdef LOCAL freopen("input.txt", "r" , stdin); freopen("output.txt", "w", stdout); #endif int t=1; //cin>>t;
    for (int i = 1; i <= t; i++) {
    //cout<<"Case #"<<i<<": ";
    solve();
    cout<<'\n';
    }
    }