说在最前面

众所周知, NOIP pj 的第三题大部分都是 dp ,但是有可能在考场上想不到动态转移方程,所以我们就可以拿深搜骗分。

方法

  1. 深搜拿部分分

    • 剪枝
    • 记忆化
  2. 看数据范围

有时候发现,写完深搜,发现可以打表qwq!

那不就很香嘛(

实践出真知

例一:P1057 传球游戏

\(\Large\rm Link\)

法1

dfs 暴搜

期望得分:\(\rm 40pts\)

首先写出 \(dfs\) 的参数:

首先是小蛮在第几号,当然是 \(1\) ,然后是次数 \(0\)

再看递归边界

这里是环状递归边界:

if (x == 0) x = n;
if (x == n + 1) x = 1;
if (step == m) {
if (x == 1) return 1;
return 0;
}

接下来往下继续搜。

dfs(x + 1, step + 1) + dfs(x - 1, step + 1);

好! \(\rm 40pts\) 到手!

那么我们可以再看一下数据范围,那么小!直接打表啊!

因为时间关系,这里打表就不多讲解了。

法2

加上记忆化

期望得分:\(\rm 90pts\)

大家应该都知道:暴搜加上记忆化 \(≈\) 动归

所以我们加上记忆化:

定义一个 \(a\) 数组,表示在某一个位置经过 \(step\) 步能否回到起始位置的方法数。

if (a[x][step] != 0) return a[x][step];

放上 dfs 代码:

int dfs (int x, int step) {
if (x == 0) x = n;
if (x == n + 1) x = 1;
if (step == m) {
if (x == 1) return 1;
return 0;
}
return dfs(x + 1, step + 1) + dfs(x - 1, step + 1);
}

为什么是 90 分???

因为想一下,如果是奇数,那么永远传不到小蛮手中,就会肯定 T 。

法3

加一个特判。

期望得分: \(100pts\)

    if (n % 2 == 0 && m % 2 == 1) {
cout << 0;
return 0;
}

法4

既然这题的正解是 dp,那么我们还是要讲讲 dp 的。

其实 dp 和记忆化没有很大的区别。

状态表示:\(\rm f[i][j]\) 表示第 \(i\) 次传球后球在第 \(j\) 个小朋友手上回到小蛮手中的方案数。

我们发现 \(\rm f[i][j]\) 跟 \(\rm a[x][step]\) 是很像的。

状态转移:\(\rm f[i][j] =
\begin{cases}
\rm f[i - 1][j - 1] & \text{第 i 次传球从左边传给 j}\\
\rm f[i - 1][j + 1] & \text{第 i 次传球从右边传给 j}
\end{cases}\)

这样写对不对?不对!

因为这是环状的,环状的解决方法通常是 \(\mod n\)

\((x + n - 1) \mod n + 1\)

所以正确状态转移为:\(\rm f[i][j] =
\begin{cases}
\rm f[i - 1][(j - 1 + n - 1) \mod n + 1] & \text{第 i 次传球从左边传给 j}\\
\rm f[i - 1][(j + 1 + n - 1) \mod n + 1] & \text{第 i 次传球从右边传给 j}
\end{cases}\)

所以:\(\rm f[i][j] = f[i - 1][(j - 1 + n - 1) \mod n + 1] + f[i - 1][(j + 1 + n - 1) \mod n + 1]\)

做完,最后放上 AC 代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<string>
#define line cout << endl
using namespace std;
int f[35][35];
int n, m;
int main() {
cin >> n >> m;
f[1][n] = f[1][2] = 1;
for (int i = 2; i <= m; i++) {
for (int j = 1; j <= n; j++) {
f[i][j] = f[i - 1][(j - 1 + n - 1) % n + 1] + f[i - 1][(j + 1 + n - 1) % n + 1];
}
}
cout << f[m][1] << endl;
return 0;
}

【笔记】「pj复习」深搜——拿部分分的更多相关文章

  1. 【笔记】「pj复习」深搜——简单剪枝

    深搜--简单剪枝 说在最前面: 因为马上要 NOIP2020 了,所以菜鸡开始了复习qwq. pj 组 T1 ,T2 肯定要拿到满分的,然后 T3 , T4 拿部分分, T3 拿部分分最常见的做法就是 ...

  2. 「PKUWC 2018」随机算法 (60分部分分做法)

    明天就是CTSC的DAY 2了qwq,晚上敲敲暴力攒攒RP,果断随便看了个题就是打暴力hhhhh 前50% O(3^N) 暴力没什么好说的,我们设F[S][s]为已经选了S集合中的点,并且这个集合中的 ...

  3. 「Android 开发」入门笔记

    「Android 开发」入门笔记(界面编程篇) ------每日摘要------ DAY-1: 学习笔记: Android应用结构分析 界面编程与视图(View)组件 布局管理器 问题整理: Andr ...

  4. 「一入 Java 深似海 」系列课程

    第一期 「一入 Java 深似海 」系列课程 - 第一期 第一节:Java 语言基础

  5. 算法学习笔记(六) 二叉树和图遍历—深搜 DFS 与广搜 BFS

    图的深搜与广搜 复习下二叉树.图的深搜与广搜. 从图的遍历说起.图的遍历方法有两种:深度优先遍历(Depth First Search), 广度优先遍历(Breadth First Search),其 ...

  6. Note -「Lagrange 插值」学习笔记

    目录 问题引入 思考 Lagrange 插值法 插值过程 代码实现 实际应用 「洛谷 P4781」「模板」拉格朗日插值 「洛谷 P4463」calc 题意简述 数据规模 Solution Step 1 ...

  7. Note -「动态 DP」学习笔记

    目录 「CF 750E」New Year and Old Subsequence 「洛谷 P4719」「模板」"动态 DP" & 动态树分治 「洛谷 P6021」洪水 「S ...

  8. Note -「单位根反演」学习笔记

    \(\mathcal{Preface}\)   单位根反演,顾名思义就是用单位根变换一类式子的形式.有关单位根的基本概念可见我的这篇博客. \(\mathcal{Formula}\)   单位根反演的 ...

  9. fir.im Weekly - 如何打造 Github 「爆款」开源项目

    最近 Android 转用 Swift 的传闻甚嚣尘上,Swift 的 Github 主页上已经有了一次 merge>>「Port to Android」,让我们对 Swift 的想象又多 ...

随机推荐

  1. 七:Redis的持久化

    1.RDB(Redis DataBase) 1.1 定义:在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是行话讲的snapshot快照,他恢复时是将快照文件直接读到内存里 是什么:Redis会单 ...

  2. rootfs如何取消登录超时

    一种简便的办法,在etc/inittab文件中,增加一行::respawn:-/bin/login.之后当登录超时后,还会在进入到登录界面,就不会出现登录超时后无法在登录的问题了. #first:ru ...

  3. webug第四关:告诉你了flang是5位数

    第四关:告诉你了flang是5位数 开始看到有点懵 于是不要脸的看源码 burp跑弱口令

  4. ctf-工具-binwalk

    binwalk在玩杂项时是个不可缺的工具.1.最简单的,在玩隐写时,首先可以用它来找到其中的字符串例如:在铁人三项,东北赛区个人赛中,有一道题它直接给了一个文件,没有后缀,不知道是什么文件先binwa ...

  5. 又陷入知识盲区了,面试被问SpringBoot集成dubbo,我当时就懵了

    前言 前两天在和粉丝聊天的时候,粉丝跟我说之前在面试的时候被问到SpringBoot这一块的知识被问的有点懵,和我问了不少这方面的东西.事后我想了想不如把这些东西分享出来吧,让更多的人看到,这样不管是 ...

  6. Fruity Parametric EQ 2使用说明(二)——FL Studio插件教程

    Fruity Parametric EQ 2均衡器,是一款我们在FL Studio制作音乐时经常会用到的插件,它是EQ中的战斗鸡,它不仅有一个高级的 7 波段参数均衡器,还具有声谱分析能力.我们在对很 ...

  7. RabbitMQ PHP扩展安装

    RabbitMQ PHP扩展安装 # 安装rabbitmq-c依赖包 yum install libtool autoconf # 安装rabbitmq-c ( 最好下载 0.5的,0.6安装可能会报 ...

  8. Mac 安装Homebrew慢的问题解决

    一开始安装,在官网上的命令: /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/ma ...

  9. 如何实现一个简易版的 Spring - 如何实现 Setter 注入

    前言 之前在 上篇 提到过会实现一个简易版的 IoC 和 AOP,今天它终于来了...相信对于使用 Java 开发语言的朋友们都使用过或者听说过 Spring 这个开发框架,绝大部分的企业级开发中都离 ...

  10. arthas监控elasticsearch(7.x)

    arthas介绍 arthas是Alibaba推出的java诊断工具 官方文档 准备 准备docker环境 name port centos_arthas 3658:3658 docker run - ...