落谷Loj

Description

定义机动路径为:

  • 没有自环
  • 路径至少包含两个格子
  • 从起点开始每一步都向不远离终点的方向移动

相同地形序列指路径上顺序经过的地形序列。

定义机动路径的权值为相同地形序列的数量之和。

求所有机动路径的权值之和。

Solution

同一类机动路径,他的贡献就是数量的平方 \(\Leftrightarrow\) 答案即本质不同机动路径数量的平方和 \(\Leftrightarrow\) 即两个人走的机动路径形式相同的方案总和。

由于 从起点开始每一步都向不远离终点的方向移动 这一性质,所以只要我们确定了他移动的 \(x, y\) 方向,那么就可以 \(DP\) 了,因为具有了无后效性。那就枚举一下两个人走的方向。

对于一个人来说,分为左上、左下、右上、右下(一类型)、正上方、正下方、正右方、正左方(二类型)四种状态。

发现一类型包含二类型,所以要简单的容斥一下:

  • 如果两个人都是一类型,那么权值贡献是 \(+\)。

  • 如果两个人 \(1\) 个一类型,\(1\) 个二类型,那么是 \(-\)。

  • 如果两个都是二类型,那么要 \(+\)。

然后当前的 \(f_{a,b,c,d}\) 表示第一个人在 \((a, b)\) ,第二个人在 \((c, d)\)。从起点走到这两个地方的方案数。

把能走的方式处理一下,然后写记搜就行。

复杂度

\(O(64n^2m^2)\)

此题卡常,可以利用 \(work(a, b, c, d) = work(c, d, a, b)\) 的对称性来减小 \(2\) 倍常数

#include <iostream>
#include <cstdio>
#include <cstring>
#define rint register int
using namespace std; const int N = 31, P = 1e9 + 9; int n, m, ans, dx[2][3], dy[2][3], cnt[2], f[N][N][N][N], w[3][3][3][3];
char g[N][N]; int inline dp(int a, int b, int c, int d) {
if (a < 1 || a > n || b < 1 || b > m || c < 1 || c > n || d < 1 || d > m || g[a][b] != g[c][d]) return 0;
if (~f[a][b][c][d]) return f[a][b][c][d];
rint &v = f[a][b][c][d] = 1;
for (rint i = 0; i < cnt[0]; i++)
for (rint j = 0; j < cnt[1]; j++)
(v += dp(a - dx[0][i], b - dy[0][i], c - dx[1][j], d - dy[1][j])) %= P;
return v;
} void prework(int o, int x, int y) {
cnt[o] = 0;
for (int a = -1; a <= 1; a++) {
if (a && a != x) continue;
for (int b = -1; b <= 1; b++) {
if ((b && b != y) || (!a && !b)) continue;
dx[o][cnt[o]] = a, dy[o][cnt[o]] = b, cnt[o]++;
}
}
} int inline work(int a, int b, int c, int d) {
if (~w[a + 1][b + 1][c + 1][d + 1]) return w[a + 1][b + 1][c + 1][d + 1];
prework(0, a, b); prework(1, c, d);
memset(f, -1, sizeof f);
int res = 0;
for (rint i = 1; i <= n; i++)
for (rint j = 1; j <= m; j++)
for (rint k = 1; k <= n; k++)
for (rint l = 1; l <= m; l++) (res += dp(i, j, k, l)) %= P;
w[a + 1][b + 1][c + 1][d + 1] = w[c + 1][d + 1][a + 1][b + 1] = res;
return res;
} int main() {
memset(w, -1, sizeof w);
scanf("%d%d", &n, &m);
for (int i = 1; i <= n; i++) scanf("%s", g[i] + 1);
for (int a = -1; a <= 1; a++) {
for (int b = -1; b <= 1; b++) {
if (!a && !b) continue;
for (int c = -1; c <= 1; c++) {
for (int d = -1; d <= 1; d++) {
if (!c && !d) continue;
if ((a * b && c * d) || (!(a * b) && !(c * d))) (ans += work(a, b, c, d)) %= P;
else ans = (ans - work(a, b, c, d) + P) % P;
}
}
}
}
printf("%d\n", ans);
return 0;
}

BJOI2017 机动训练的更多相关文章

  1. [BZOJ4859][BJOI2017]机动训练(DP)

    4859: [BeiJing2017]机动训练 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 105  Solved: 63[Submit][Stat ...

  2. P3713 [BJOI2017]机动训练

    这个题简直神仙,求相同路径的平方就等于两个人走相同路径的方案数.然后...暴力搜索+记忆化就行了,比较玄学. 题干: 题目描述 整个岛可以看作一片 n*m 的区域,每个格子有自己的地形. 一条路径由一 ...

  3. 【LOJ】#2178. 「BJOI2017」机动训练

    题解 遇见平方和就转有序对呗 dp类似从很多点出发每次走一步的转移方式 然后我too naive的,枚举路径长度来决定更新次数,愉快TLE 改成记搜就过了 代码 #include <bits/s ...

  4. bzoj 4859 [BeiJing2017]机动训练

    题面 https://www.lydsy.com/JudgeOnline/problem.php?id=4859 题解 和管道取珠类似 首先把平方转化成两条路径经过的图案相同的方案数 对于一条路径 方 ...

  5. AHOI2018训练日程(3.10~4.12)

    (总计:共90题) 3.10~3.16:17题 3.17~3.23:6题 3.24~3.30:17题 3.31~4.6:21题 4.7~4.12:29题 ZJOI&&FJOI(6题) ...

  6. NOI Online #2 提高组 游记

    没 NOI Online 1 挂的惨就来写游记吧,不知道为啥 NOI Online 1 民间数据测得 60 分的 T1 最后爆零了... 昏昏沉沉的醒来,吃了早饭,等到 \(8:30\) 进入比赛网页 ...

  7. 一个小 Trick

    平方变两次 一个状态 \(S\) 有一个贡献,所有状态 \(S\) 组成集合 \(U\) . 然后我们要统计下面这个东西 \[ans=\sum_{S\in U}f^2(S) \] 然后我们就可以看作是 ...

  8. BJOI做题记录

    BJOI做题记录 终于想起还要做一下历年省选题了2333 然而咕了的还是比做了的多2333 LOJ #2178. 「BJOI2017」机动训练 咕了. LOJ #2179. 「BJOI2017」树的难 ...

  9. SSD框架训练自己的数据集

    SSD demo中详细介绍了如何在VOC数据集上使用SSD进行物体检测的训练和验证.本文介绍如何使用SSD实现对自己数据集的训练和验证过程,内容包括: 1 数据集的标注2 数据集的转换3 使用SSD如 ...

随机推荐

  1. 1. 线性DP 120. 三角形最小路径和

    经典问题: 120. 三角形最小路径和  https://leetcode-cn.com/problems/triangle/ func minimumTotal(triangle [][]int) ...

  2. shell编程之字符串操作

    shell中字符串操作主要有以下几种,其中:pattern ,old中可以使用通配符: ${#var} :返回字符串变量var的长度 ${var:m} :返回${var}中从第m+1个字符到最后的部分 ...

  3. 使用spring框架进行aop编程实现方法调用前日志输出

    aop编程 之使用spring框架实现方法调用前日志输出 使用spring框架实现AOP编程首先需要搭建spring框架环境: 使用Spring框架实现AOP工程编程之后,不需要我们去写代理工厂了,工 ...

  4. mysql之优化器、执行计划、简单优化

    mysql之优化器.执行计划.简单优化 2018-12-12 15:11 烟雨楼人 阅读(794) 评论(0) 编辑 收藏 引用连接: https://blog.csdn.net/DrDanger/a ...

  5. Android RFID调试总结

    调试了包括驱动,jni层,当然也熟悉了下应用层.    1. 驱动层包括修改:        device/eastaeon/aeon6735_65c_l/init.project.rc    //去 ...

  6. CorelDRAW常用工具之橡皮擦工具

    很多作图以及设计软件都会自带橡皮擦工具,但对于专业做平面设计的小伙伴来说,普通的橡皮工具肯定是无法满足日常作图需求的,今天来看看CorelDRAW的橡皮擦能玩出什么花样来. 1.擦除对象 CorelD ...

  7. jQuery 第五章 实例方法 详解内置队列queue() dequeue() 方法

    .queue() .dequeue() .clearQueue() ------------------------------------------------------------------ ...

  8. 【震惊】手把手教你用python做绘图工具(一)

    在这篇博客里将为你介绍如何通过numpy和cv2进行结和去创建画布,包括空白画布.白色画布和彩色画布.创建画布是制作绘图工具的前提,有了画布我们就可以在画布上尽情的挥洒自己的艺术细胞. 还在为如何去绘 ...

  9. LaTeX中的插图

    插图代码及注释: 显示效果: 更多命令可以看相关文档,通过在命令行终端输入 texdoc graphicx 命令打开文档.

  10. 【NOIP2015模拟11.5】JZOJ8月5日提高组T3 旅行

    [NOIP2015模拟11.5]JZOJ8月5日提高组T3 旅行 题目 若不存在第\(k\)短路径时,输出"Stupid Mike" 题解 题意 给出一个有\(n\)个点的树 问这 ...