[递推]D. 【例题4】传球游戏
D
.
【
例
题
4
】
传
球
游
戏
D. 【例题4】传球游戏
D.【例题4】传球游戏




题目解析
设
t
(
i
,
j
)
t(i,j)
t(i,j)为过了
j
j
j轮,轮到
i
i
i手上的总方案数,而小蛮的编号这里设为
t
(
1
,
j
)
t(1,j)
t(1,j).
因为如果只有
1
1
1人,那么可以得出:
t
(
1
,
0
)
=
1
t(1,0)=1~~~~~~~~~~~~~~~
t(1,0)=1 (不经过任何传递 )
同题目所述,是可以向左和右传递,那么就可以得出递推式
t
(
i
,
j
)
=
t
(
i
−
1
,
j
−
1
)
+
t
(
i
+
1
,
j
−
1
)
t(i,j)=t(i-1,j-1)+t(i+1,j-1)
t(i,j)=t(i−1,j−1)+t(i+1,j−1)
j
−
1
j-1
j−1是因为少了由
i
−
1
i-1
i−1或
i
+
1
i+1
i+1到
i
i
i的轮数.
但是,这是一个环,我们要考虑边界问题:
所以当
i
=
n
i=n
i=n时,就是由
t
(
i
−
1
,
j
−
1
)
,
t
(
1
,
j
−
1
)
t(i-1,j-1),t(1,j-1)
t(i−1,j−1),t(1,j−1)传递来的
同理,当
i
=
1
i=1
i=1时,就是由
t
(
n
,
j
−
1
)
,
t
(
i
+
1
,
j
−
1
)
t(n,j-1),t(i+1,j-1)
t(n,j−1),t(i+1,j−1)传递来的
那么就能得出递推式(边界问题略):
t
(
i
,
j
)
=
{
t
(
1
,
0
)
=
1
t
(
i
,
j
)
=
t
(
i
−
1
,
j
−
1
)
+
t
(
i
+
1
,
j
−
1
)
;
t(i,j) = \left\{\begin{matrix} & t(1,0)=1\\ & t(i,j)=t(i-1,j-1)+t(i+1,j-1);\\ \end{matrix}\right.
t(i,j)={t(1,0)=1t(i,j)=t(i−1,j−1)+t(i+1,j−1);
Code
注意循坏变量!与解析相反!
#include <bits/stdc++.h>
#define ll long long
using namespace std;
int n, m;
ll t[35][35];
int main ()
{
scanf ("%d%d", &n, &m);
t[1][0] = 1; // 不经过任何传递
for (int i = 1; i <= m; ++ i)
{
for (int j = 1; j <= n; ++ j)
{
int a = j - 1, b = j + 1;
if (j == 1) a = n; // 边界
if (j == n) b = 1; // 边界
t[j][i] = t[a][i - 1] + t[b][i - 1]; // 递推式
}
}
printf ("%lld ", t[1][m]);
return 0;
}
[递推]D. 【例题4】传球游戏的更多相关文章
- CH3401 石头游戏(矩阵快速幂加速递推)
题目链接:传送门 题目: 石头游戏 0x30「数学知识」例题 描述 石头游戏在一个 n 行 m 列 (≤n,m≤) 的网格上进行,每个格子对应一种操作序列,操作序列至多有10种,分别用0~9这10个数 ...
- CH 3401 - 石头游戏 - [矩阵快速幂加速递推]
题目链接:传送门 描述石头游戏在一个 $n$ 行 $m$ 列 ($1 \le n,m \le 8$) 的网格上进行,每个格子对应一种操作序列,操作序列至多有 $10$ 种,分别用 $0 \sim 9$ ...
- [递推]C. 【例题3】数的划分
C . [ 例 题 3 ] 数 的 划 分 C. [例题3]数的划分 C.[例题3]数的划分 题目描述 将整数 n n n 分成 k k k 份,且每份不能为空,任意两个方案不相同(不考虑顺序). 例 ...
- [递推] A. 【例题1】错排问题
A. [例题1]错排问题 题目描述 求多少个 n n n个数的排列 A A A ,满足对于任意的 i ( 1 ≤ i ≤ n ) i(1 ≤ i ≤ n) i(1≤i≤n) 使 A i ≠ i Ai ...
- Crash的游戏 [组合+递推]
题面 思路 问题转化 这个问题的核心在于,我们需要把"加入一个球.拿出一个球"这两个操作转化一下 因为显然两个操作同时进行的话,我们没有办法从单纯的组合意义去分析 我们首先把$m$ ...
- 紫书 例题 9-9 UVa 10003 (区间dp+递推顺序)
区间dp,可以以一个区间为状态,f[i][j]是第i个切点到第j个切点的木棍的最小费用 那么对于当前这一个区间,枚举切点k, 可以得出f[i][j] = min{dp(i, k) + dp(k, j) ...
- 紫书 例题 9-4 UVa 116 ( 字典序递推顺序)
这道题在递推方式和那个数字三角形有一点相像,很容易推出来 但是这道题要求的是字典序,这里就有一个递推顺序的问题 这里用逆推,顺推会很麻烦,为什么呢? 如果顺推的话,最后一行假设有种情况是最小值,那么你 ...
- 洛谷 P1057 传球游戏 解题报告
P1057 传球游戏 题目描述 上体育课的时候,小蛮的老师经常带着同学们一起做游戏.这次,老师带着同学们一起做传球游戏. 游戏规则是这样的:n个同学站成一个圆圈,其中的一个同学手里拿着一个球,当老师吹 ...
- NOIP 2008 传球游戏
洛谷 P1057 传球游戏 洛谷传送门 JDOJ 1536: [NOIP2008]传球游戏 T3 JDOJ传送门 Description 上体育课的时候,小蛮的老师经常带着同学们一起做游戏.这次, ...
随机推荐
- qt QTimer 计时器
#include <QtCore> #include <QTimer> QTimer *timer; timer = new QTimer(this); connect(tim ...
- js generator和yield
function co<T>(fn: () => Generator<any, any, any>): Promise<T> { const g: Gener ...
- Scrapy项目_阳光热线问政平台
目的: 爬取阳光热线问政平台问题中每个帖子的标题.详情URL.详情内容.图片以及发布时间 步骤: 1.创建爬虫项目 1 scrapy startproject yangguang 2 cd yangg ...
- vue路由理解
vue路由:就是一个菜单的概念比如说有一个菜单栏,菜单栏上有很多按钮,当你点击一个按钮时会出现不同的页面,这就是vue路由
- nginx日志文件切分
定义cut_nginx_log.sh 日志文件脚本如下 #!/bin/bash#LOGS_PATH为日志存放路径LOGS_PATH=/weblog/nginx/logsYESTERDAY=$(date ...
- Redis持久化机制 RDB和AOF的区别
一.简单介绍 Redis中的持久化机制是一种当数据库发生宕机.断电.软件崩溃等,数据库中的数据无法再使用或者被破坏的情况下,如何恢复数据的方法. Redis中共有两种持久化机制 RDB(Redis D ...
- Python3.x 基础练习题100例(11-20)
练习11: 题目: 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 分析: 兔子的规律为数列1,1,2, ...
- MySQL注入流程
目录 确认注入点 信息收集 数据获取 提权 写个MySQL注入流程的大纲,类似一份全局地图,能指导下一步工作.MySQL注入流程分为四步: 确认注入点 信息收集 数据获取 提权 确认注入点 参考:ht ...
- java基础知识 + 常见面试题
准备校招面试之Java篇 一. Java SE 部分 1.1 Java基础 1. 请你解释Object若不重写hashCode()的话,hashCode()如何计算出来的? Object 的 hash ...
- 剑指 Offer 41. 数据流中的中位数 + 堆 + 优先队列
剑指 Offer 41. 数据流中的中位数 Offer_41 题目详情 题解分析 本题使用大根堆和小根堆来解决这个寻找中位数和插入中位数的问题. 其实本题最直接的方法是先对数组进行排序,然后取中位数. ...