传球游戏-pascal

题目描述见tyvj

复制代码
View Code
 1 program sky;
2 var
3 i,j,m,n : longint;
4 a : array[0..50,0..50] of longint;
5 begin
6 readln(n,m);
7 a[0,1]:=1;
8 for i:=1 to m do
9 begin
10 a[i,1]:=a[i-1,n]+a[i-1,2];
11 for j:=2 to n-1 do a[i,j]:=a[i-1,j-1]+a[i-1,j+1];
12 a[i,n]:=a[i-1,n-1]+a[i-1,1];
13 end;
14 writeln(a[m,1]);
15 end.
复制代码

朴素的代码

状态f[i,j]表示第i步走到第j个位置的方案数。
DP方程f[i,j]:=f[i-1,j-1]+f[i-1,j+1];

不看不会打,看了之后一下子打过了。哎。。

如此朴素的递推啊。。。

posted @   SunSky...  阅读(585)  评论(1编辑  收藏  举报
编辑推荐:
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
阅读排行:
· C# 13 中的新增功能实操
· Ollama本地部署大模型总结
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(4)
· langchain0.3教程:从0到1打造一个智能聊天机器人
· 用一种新的分类方法梳理设计模式的脉络
点击右上角即可分享
微信分享提示