博客
关于我
[牛客练习赛69] D. 火柴排队 多维dp+逆元+递推求排列组合
阅读量:334 次
发布时间:2019-03-04

本文共 1983 字,大约阅读时间需要 6 分钟。

??????????????????????????????

????

???????n???a?????????k??????????????d??????????????????????a_i < a_j???????a_i' < a_j'????

???????????????????????????????????????????????????????????

??????????????????????????dp[i][j][k]??i??????j????????k???i?????????

????????

  • ????????dp[i][j][0] = dp[i-1][j][0] + dp[i-1][j][1] * (a[i-1] + d ? a[i])
  • ???????dp[i][j][1] = dp[i-1][j-1][0] + dp[i-1][j-1][1]
  • ??????

    ???????????????????????????

    ????

    #include 
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include
    using namespace std;typedef long long ll;const double PI = acos(-1.0);const double eps = 1e-6;const ll mod = 998244353;const int inf = 0x3f3f3f3f;const int maxn = 5000 + 10;void get_comb(int n) { c[0] = 1; for (int i = 1; i <= n; ++i) { c[i] = (n - i + 1) * c[i - 1] % mod * inv(i) % mod; }}ll inv(ll a) { return pow(a, mod - 2, mod);}void main() { ll n, d; scanf("%lld %lld", &n, &d); get_comb(n); vector
    a(n + 1); for (int i = 1; i <= n; ++i) { scanf("%lld", &a[i]); } sort(a + 1, a + n + 1); dp[1][1][1] = 1; dp[1][0][0] = 1; for (int i = 2; i <= n; ++i) { for (int j = 0; j <= i; ++j) { if ((i - 1) & 1) { dp[i & 1][j][0] = (dp[i - 1 & 1][j][0] + dp[i - 1 & 1][j][1] * (a[i - 1] + d <= a[i])) % mod; dp[i & 1][j][1] = (dp[i - 1 & 1][j - 1][1] + dp[i - 1 & 1][j - 1][0]) % mod; } else { dp[i & 1][j][0] = (dp[i - 1][j][0] + dp[i - 1][j][1] * (a[i - 1] + d <= a[i])) % mod; dp[i & 1][j][1] = (dp[i - 1][j - 1][1] + dp[i - 1][j - 1][0]) % mod; } } } for (int i = 1; i <= n; ++i) { ll ans = (dp[n & 1][i][0] + dp[n & 1][i][1]) % mod; ans = ans * pow(c[i], mod - 2, mod) % mod; ans = (ans + mod) % mod; printf("%lld\n", ans); }}

    ????

  • ??????????????????????????
  • ????????dp[1][0][0]?dp[1][1][1]????1?
  • ??????????????????????dp??
  • ????????k????????????????????????
  • ????????O(n^2)???????????????n=5000????

    转载地址:http://yqmh.baihongyu.com/

    你可能感兴趣的文章
    Oracle 递归函数与拼接
    查看>>
    oracle 逻辑优化,提升高度,综合SQL上下文进行逻辑优化
    查看>>
    oracle 闪回关闭,关闭闪回即disable flashback的操作步骤
    查看>>
    oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
    查看>>
    oracle--用户,权限,角色的管理
    查看>>
    Oracle-定时任务-JOB
    查看>>
    oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>
    Oracle10g EM乱码之快速解决
    查看>>
    Oracle10g下载地址--多平台下的32位和64位
    查看>>
    Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
    查看>>
    oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
    查看>>
    Oracle11G基本操作
    查看>>
    Oracle11g服务详细介绍及哪些服务是必须开启的?
    查看>>
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>
    Oracle——distinct的用法
    查看>>
    Oracle、MySQL、SQL Server架构大对比
    查看>>
    oracle下的OVER(PARTITION BY)函数介绍
    查看>>