【字符串】ABC324E

退役啦,接下来的博客全是图一乐啦 

E - Joint Two Strings

题意

思路

统计两个指针的方案数一定是枚举一个,统计另一个

然后因为拼起来之后要包含 t 这个字符串,隐隐约约会感觉到和前缀后缀子序列有关

考虑预处理每个 s[i] 的最长公共前缀子序列 和 最长公共后缀子序列,接下来问题就变成:

满足ai + bj >= m有多少对 (i, j),这个直接值域统计一下即可

#include <bits/stdc++.h>

#define int long long

constexpr int N = 5e5 + 10;
constexpr int M = 1e4 + 10;
constexpr int mod = 1e9 + 7;
constexpr int Inf = 0x3f3f3f3f;

std::string t, s[N];

int n;
int pre[N], suf[N];
int mp[N];

void solve() {
    std::cin >> n >> t;
    int m = t.size();
    t = " " + t;
    for (int i = 1; i <= n; i ++) {
        std::cin >> s[i];
        s[i] = " " + s[i];
    }
    for (int i = 1; i <= n; i ++) {
        int len = s[i].size() - 1;
        pre[i] = 1;
        for (int j = 1; j <= len; j ++) {
            if (pre[i] <= m && t[pre[i]] == s[i][j]) {
                pre[i] += 1;
            }
        }
        pre[i] -= 1;
        suf[i] = m;
        for (int j = len; j >= 1; j --) {
            if (suf[i] >= 1 && t[suf[i]] == s[i][j]) {
                suf[i] -= 1;
            }
        }
        suf[i] += 1;
        mp[suf[i]] += 1;
    }
    for (int i = 2; i <= m + 1; i ++) {
        mp[i] += mp[i - 1];
    }
    int ans = 0;
    for (int i = 1; i <= n; i ++) {
        ans += mp[pre[i] + 1];
    }
    std::cout << ans << "\n";
}
signed main(){
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);

    int t = 1;
    while(t --) {
        solve();
    }
    return 0;
}

 

相关推荐

  1. ABC344 A-E题解

    2023-12-14 17:38:03       23 阅读
  2. ABC349 A-E题解

    2023-12-14 17:38:03       10 阅读
  3. Leetcode的AC指南 —— 字符串344. 反转字符串

    2023-12-14 17:38:03       45 阅读
  4. [ABC206E] Divide Both 解题记录

    2023-12-14 17:38:03       17 阅读
  5. 字符串AC自动机

    2023-12-14 17:38:03       33 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-14 17:38:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-14 17:38:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-14 17:38:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-14 17:38:03       20 阅读

热门阅读

  1. 二、python selenium爬虫

    2023-12-14 17:38:03       45 阅读
  2. Docker 安装 AWVS 与 Nessus(2023/12/14)

    2023-12-14 17:38:03       49 阅读
  3. 1. cgal在ubuntu下的安装及Hello World的测试

    2023-12-14 17:38:03       49 阅读
  4. 宏任务和微任务的区别

    2023-12-14 17:38:03       42 阅读
  5. python进阶:上下文管理器和with语句

    2023-12-14 17:38:03       41 阅读
  6. 关于C++的一些小知识点

    2023-12-14 17:38:03       32 阅读
  7. python pandas 数据预处理

    2023-12-14 17:38:03       40 阅读
  8. mysql参数笔记

    2023-12-14 17:38:03       44 阅读