当前位置: 首页 > article >正文

dp + 计数,CF 1920 E - Counting Binary Strings

目录

一、题目

1、题目描述

2、输入输出

2.1输入

2.2输出

3、原题链接

二、解题报告

1、思路分析

2、复杂度

3、代码详解


一、题目

1、题目描述

2、输入输出

2.1输入

2.2输出

3、原题链接

E - Counting Binary Strings

二、解题报告

1、思路分析

对于一个01串,我们怎么计算其好子串的数目呢?

000 1 0000 1 00 1 00000

   3        4         2        5

数目 = 4 * 5 + 5 * 3 + 3 * 6

可见,我们只关注 连续0 的组数

考虑dp,为了转移我们显然要知道最后一段的0的长度

定义 f(sum, cur)  为 好子串个数为sum,最后一段0的长度为cur,的字符串的数目

我们枚举cur 前一个 0串的长度,pre

那么 f(sum, cur) = Σ f(sum - (cur + 1) * (pre + 1), pre)

最终输出 sum(f(n)) 即可

2、复杂度

时间复杂度: O(nklogn)空间复杂度:O(nk)

3、代码详解

 ​
#include <bits/stdc++.h>
// #include <ranges>

using u32 = unsigned;
using i64 = long long;
using u64 = unsigned long long;

constexpr int P = 998244353;
constexpr int inf32 = 1E9 + 7;

void solve() {
    int n, k;

    std::cin >> n >> k;

    std::vector<std::vector<int>> f(n + 1, std::vector<int>(k + 1));

    int res = 0;

    f[0].assign(n + 1, 1);

    for (int sum = 1; sum <= n; ++ sum) {
        for (int cur = 0; cur < k; ++ cur) {
            for (int pre = 0; (cur + 1) * (pre + 1) <= sum and cur + pre < k; ++ pre) {
                f[sum][cur] += f[sum - (pre + 1) * (cur + 1)][pre];
                if (f[sum][cur] >= P) f[sum][cur] -= P;
            }
        }
    }

    for (int x : f[n]) {
        res += x;
        if (res >= P) res -= P;
    }

    std::cout << res << '\n';
}

int main() {
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);
    
    int t = 1;
    std::cin >> t;
    
    while (t--) {
        solve();
    }
    
    return 0;
}


http://www.kler.cn/a/301713.html

相关文章:

  • MMDetection框架下的常见目标检测与分割模型综述与实践指南
  • 人工智能与物联网:智慧城市的未来
  • 系统思考与因果智慧
  • 1688平台商品关键词搜索的多样性与Python爬虫应用实践
  • 【HarmonyOS NEXT】鸿蒙应用实现屏幕录制详解和源码
  • 《鸿蒙系统AI技术:筑牢复杂网络环境下的安全防线》
  • ‌汽车一键式启动系统‌包含哪些功能
  • ARM32开发——DMA
  • C++ 二叉树进阶
  • STM32L051K8U6-HAL-串口中断控制灯闪烁速度
  • php反序列化基础
  • ultralytics实现DeepSort之级联匹配
  • 学习Vue3的第五天
  • MAC 地址简化概念(有线 MAC 地址、无线 MAC 地址、MAC 地址的随机化)
  • Android Radio2.0——有效电台扫描(八)
  • 【网络】高级IO——五种IO模式
  • 概念——二连杆与三连杆解算
  • VS2019界面介绍
  • vue3+ant design vue动态实现级联菜单~
  • Gradle和Maven
  • 第四部分:1---文件内核对象,文件描述符,输出重定向
  • Unity基本操作
  • 前端封装组件可视化库
  • 第15-05章:获取运行时类的完整结构
  • 【AcWing】871. 约数之和
  • Spring Security 快速开始