poj 3036 Honeycomb Walk 暴力枚举 dp

题意:

蜜蜂走n步后回到原始位置的不同走法

分析:

把以正六边形建立坐标系那么(0,0)点可达(1,0)(0,1)(1,1)(0,-1)(-1,0)(-1,-1)

然后暴力循环求解

ACcode:

#include 
#include 
#include 
#include 
#include 
#define maxn 150005
#define inf 0x3f3f3f3f
#include 
#define ll long long
using namespace std;
ll dp[15][50][50];
int dx[]={1,0,1,-1,0,-1};
int dy[]={0,1,1,0,-1,-1};
int main(){int n,loop;memset(dp,0,sizeof(dp));dp[0][7][7]=1;for(int k=1;k<=14;++k)for(int i=0;i<=14;++i)for(int j=0;j<=14;++j)for(int t=0;t<6;++t)dp[k][i][j]+=dp[k-1][i+dx[t]][j+dy[t]];scanf("%d",&loop);while((loop--)&&scanf("%d",&n))printf("%I64d\n",dp[n][7][7]);return 0;
}



本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部