19184 传球游戏

时间限制:1000MS 代码长度限制:10KB
提交次数:0 通过次数:0

题型: 编程题 语言: G++;GCC;VC;JAVA

Description

n个同学站成一个圆圈,其中的一个同学手里拿着一个球,每个同学可以把球传给自己左右的两个同学中的一个(左右任意)。
从1号同学手里开始传的球,传了m次以后,又回到1号同学手里,请问有多少种不同的传球方法。
两种传球方法被视作不同的方法,当且仅当这两种方法中,接到球的同学按接球顺序组成的序列是不同的。
比如有三个同学1号、2号、3号,球传了3次回到1号手里的方式有1->2->3->1和1->3->2->1,共2种。

输入格式

一行,有两个用空格隔开的整数n,m(3≤n≤30,1≤m≤30)。

输出格式

符合题意的方法数。

输入样例

3 3

输出样例

2

解题思路

一、深度优先搜索

解题思路

搜索即将所有情况列出来,每传到一个同学手中时,他都有两种选择,一个是往左传,一个是往右传,我们只要计算传到最后一次时是否传回第一个人手中即可。

类似于击鼓传花,只不过击鼓传花结束条件是时间到了,而这题的结束条件是传的次数到了

算法思路

  1. 递归的传参有两个,一个是记录传到第几次,一个是记录传到编号为几的人手上。
  2. 递归终止条件,达到第 m 次;如果此时符合条件(即传到第一个人手上),就将记录的 res 进行加一即可。
  3. 每次递归都有两种选择,一个是往左传,一个是往右传。
  4. 注意在编写第三步时,要分三种特殊情况,因为此题为圆圈,第一个人可以传到最后一个人手上,最后一个人可以传到第一个人手上。因此第一种情况是此时传到第一个人手中,第二种情况时此时传到最后一个人手中,第三种情况就是普通情况,传到中间任意一个人手中

补充

如果此题还要求输出传递的序列,那么便可新增一个记录序列的 nums 数组,在递归时同时压入 nums,且需要记得回溯即可(即还原状态)。

更多注释可查看下方的完整代码中,有助于理解

代码如下

#include <map>
#include <cmath>
#include <queue>
#include <stack>
#include <cstdio>
#include <vector>
#include <utility>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
/*
3 3
*/
using namespace std;
const int N = 1050;
const int inf = 1e9+7;
const int mod = 1e9+7;
const double pi = acos(-1.0);
const double eps = 1e-9;
typedef long long ll;int n, m; // n 个同学传 m 次
int res = 0;// cur 为传了几次,i 为传到序号为几的人手上
void dfs(int cur, int i) {if(cur == m + 1) {// 如果最后这次传回第1个人手上,则满足条件if(i == 1) {res++;}return;}// 由于是圈,第一个人的左手边是最后一个人if(i == 1) {dfs(cur + 1, n); // 传给左手边的人dfs(cur + 1, i + 1); // 传给右手边的人} else if(i == n) {// 由于是圈,最后一个人的右手边是第一个人dfs(cur + 1, i - 1); // 传给左手边的人dfs(cur + 1, 1); // 传给右手边的人} else{dfs(cur + 1, i - 1); // 传给左手边的人dfs(cur + 1, i + 1); // 传给右手边的人}}int main()
{cin >> n >> m;dfs(1, 1);cout << res << endl;return 0;
}

二、动态规划

1. dp 方程定义

  • a[i][j] 表示第 i 次传球传到 j 同学手里的方案数

2. 状态转移方程

当传到 j 同学手中时,传过来的位置有两种情况,一种是从左边即 j - 1,一种是从右边即 j + 1,因此 a[i][j] = a[i - 1][j - 1] + a[i - 1][j + 1]

但需要注意有特殊情况,第一个人左边是最后一个人,最后一个人右边是第一个人,所以特殊情况特殊处理即可。

  • 传到第一个人手中:a[i][j] = a[i - 1][2] + a[i - 1][n]
  • 传到最后一个人手中:a[i][j] = a[i - 1][n - 1] + a[i - 1][1]

代码如下

#include <bits/stdc++.h>
using namespace std;int main()
{int i,j,n,m,a[35][35]={0};cin>>n>>m;a[0][1]=1;for(i=1;i<=m;i++){ /**< a[i][j]表示第i次传球传到j同学手里的方案数 */for(j=1;j<=n;j++){/**< a[i][j]=a[i-1][j-1]+a[i-1][j+1] */if(j==1)a[i][j]=a[i-1][2]+a[i-1][n];else if(j==n)a[i][j]=a[i-1][n-1]+a[i-1][1];elsea[i][j]=a[i-1][j-1]+a[i-1][j+1];}}cout<<a[m][1];return 0;
}

最后

对我感兴趣的小伙伴可查看以下链接

  • 我的掘金主页:https://juejin.cn/user/1302297507801358
  • 博客主页:http://blog.zhangjiancong.top/
  • 公众号:Smooth前端成长记录

算法设计与分析 SCAU19184 传球游戏相关推荐

  1. 哈工大威海算法设计与分析_计算机算法设计与分析第一章 算法概述

    晓强Deep Learning的读书分享会,先从这里开始,从大学开始.大家好,我是晓强,计算机科学与技术专业研究生在读.我会不定时的更新我的文章,内容可能包括深度学习入门知识,具体包括CV,NLP方向 ...

  2. C++算法设计与分析课后习题(第三章)

    C++算法设计与分析课后习题[第三章] 前言 一.求2+22+222+2222+...+22...(n个2)...22(精确计算) 变量解释 运行截图 二.编写一个算法,其功能是给一维数组a输入任意6 ...

  3. 算法设计与分析: 1-4 金币阵列问题

    1-4 金币阵列问题 问题描述 有m*n枚金币在桌面上排列成一个m行n列的金币阵列.每一枚金币或正面朝上,或背面朝上.用数字表示金币状态,0表示正面朝上,1表示背面朝上. 金币阵列游戏的规则是: (1 ...

  4. 程振波 算法设计与分析_算法设计与分析

    本书按照教育部*制定的计算机科学与技术专业规范的教学大纲编写,努力与国际计算机学科的教学要求接轨.强调 算法 与 数据结构 之间密不可分的联系,因而强调融数据类型与定义在该类型上的运算于一体的抽象数据 ...

  5. C++算法设计与分析例题代码(基础篇)

    C++算法设计与分析例题代码 前言 一.求1/1!-1/3!+1/5!-1/7!+...+(-1)^(n+1)/(2n-1)! 二.一个数如果恰好等于它的因子之和(包括1,但不包含这个数本身),这个数 ...

  6. 计算机算法设计与分析(第4版) 王晓东 著 2012.2 笔记(这本书还不错,偏实用、有难度)

    计算机算法设计与分析(第4版) 目录 1 算法概述 2 递归与分治策略 3 动态规划 4 贪心算法 5 回溯法 6 分支限界法 7 随机化算法 8 线性规划与网络流 算法概述 复杂性分析 NP-完全性 ...

  7. 算法设计与分析(第4版)

    算法设计与分析(第4版) 算法引论 算法与程序 算法:解决问题的方法或过程 输入 输出 确定性 有限性 程序:算法用某种程序设计语言的具体实现 表达算法的抽象机制 高级程序设计语言 抽象数据类型 描述 ...

  8. 算法设计与分析复习笔记(上)

    简介:本文是博主在复习算法设计与分析的笔记,参考了北大算法设计与分析以及王晓东编著的<计算机算法设计与分析>第四版相关内容,如有错误,欢迎指正. 文章目录 设计技术 分治 动态规划 设计技 ...

  9. 【算法】算法设计与分析试题(含答案)

    算法设计与分析试题 (中国科学院大学-陈玉福-2011秋) 一. 回答下列问题: (每小题5分) 1.陈述算法在最坏情况下的时间复杂度和平均时间复杂度:这两种评估算法复杂性的方法各自有什么实际意义? ...

最新文章

  1. 【全栈项目上线(vue+node+mongodb)】06.nodejs服务上线(生产环境前后分离的vue项目中怎么解决跨域问题)...
  2. 信息学奥赛一本通(1217:棋盘问题)
  3. python两数相加有进退位_Leetcode_两数相加_python
  4. 训练集、测试集loss容易出现的问题总结
  5. 【致远FAQ】致远OA启动不起来了(下集)
  6. matlab电压模块,matlab simpowersystems电路仿真模块.doc
  7. java实现订单轨迹_B端零售业:订单轨迹日志功能设计思考
  8. [转]在计算机领域做研究的一些想法
  9. redis开启rdb和aof后文件正确恢复
  10. 个人图床的最简单制作-腾讯云COS
  11. CF1740H MEX Tree Manipulation
  12. 探究opencv中的moments函数和HuMoments函数
  13. 给定三角形边长,求三角形面积
  14. npm install安装时卡在sill idealTree buildDeps,npm安装速度慢,npm安装卡在一个地方不动,npm遇到ssl问题,An unknown git error occu
  15. php网页课程设报告,网页设计课程设计报告
  16. c语言中有裁剪字符串的函数吗,C语言中的字符串截取函数
  17. 软考-软件设计师 - 第2章 程序设计语言基础知识【附补充常考知识点】
  18. 解决 Unrecognized option: --add-opens=java.base/java.util.concurrent.atomic=ALL-UNNAMED 【实测有效】
  19. 在线Photoshop ps网页图片处理PHP源码
  20. 此网页包含过多的重定向

热门文章

  1. 群晖php启动失败,群晖 Synology应用程序服务更新失败的解决方法
  2. Windows11Ubuntu18.04安装OpenCV4.5.0VISP3.5.0
  3. 股票投资的24堂必修课
  4. 7、Cookie与Session
  5. 权力小责任大的项目经理如何带好项目?
  6. 媒体文章短视频如何上头条
  7. JQuery操作div隐藏和显示的4种动画
  8. 微型计算机中使用的数据库管理系统,微型机数据库管理系统—dBASE-Ⅲ 董长德编.pdf...
  9. attck-Execution
  10. iomanip在c语言中用什么代替,#includeiomanip怎么用?在c++中