首页 > 代码库 > zoj 2771 - Get Out of the Glass
zoj 2771 - Get Out of the Glass
题目:有三层玻璃叠在一起。一束斜着照耀的光纤从最上面射入,问有多少条光线反射n次。
分析:dp,分成奇偶两种状况考虑;
奇数情况:每一个面的光线等于上次的本平面以上的点的反射。
偶数情况:每一个面的光线等于上次的本平面一下的点的反射。
说明:(2011-09-19 01:29)。
#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; }
zoj 2771 - Get Out of the Glass
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。