您的位置:首页 > 其它

zoj2771 Get Out of the Glass(DP)

2011-08-17 14:27 435 查看
/*
简单DP:分成奇偶两种状况考虑
奇数情况:每个面的光线等于上次的本平面以上的点的反射
偶数情况:每个面的光线等于上次的本平面以下的点的反射
*/

View Code

#include <stdio.h>
#include <string.h>

long long F[ 61 ][ 4 ];

int main()
{
int i,j,k,n;
memset( F, 0L, sizeof( F ) );
F[ 0 ][ 0 ] = 1L;

for ( i = 1 ; i <= 60 ; ++ i )
for ( j = 0 ; j <= 3  ; ++ j )
if ( i%2 ) {
for ( k =  0  ; k < j ; ++ k )
F[ i ][ j ] += F[ i-1 ][ k ];
}else {
for ( k = j+1 ; k <= 3 ; ++ k )
F[ i ][ j ] += F[ i-1 ][ k ];
}
while ( scanf("%d",&n) != EOF ) {
long long sum = 0;
for ( i = 0 ; i < 3 ; ++ i )
sum += F[ n ][ i+n%2 ];
printf("%lld\n",sum);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: