P1057 [NOIP2008 普及组] 传球游戏

P1057 [NOIP2008 普及组] 传球游戏 ,第1张

添加链接描述
dp表示 传递i次后第j个人的方案数
当前人的方案数等于左边或者右边传递的总和

#include
using namespace std;
const int N=35;
int dp[N][N];
int main(){
    int n,m;
    cin>>n>>m;
    dp[0][1]=1;
    for(int i=1;i<=m;i++){
        for(int j=1;j<=n;j++){
            if(j==1){
                dp[i][j]+=dp[i-1][n]+dp[i-1][2];
            }
            else if(j==n){
                dp[i][j]+=dp[i-1][j-1]+dp[i-1][1];
            }
            else {
                dp[i][j]+=dp[i-1][j+1]+dp[i-1][j-1];
            }
        }
    }
    cout<<dp[m][1]<<"\n";

    return 0;
}

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/915304.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-16
下一篇2022-05-16

发表评论

登录后才能评论

评论列表(0条)

    保存