关闭

POJ 2440 DNA(递推)

120人阅读 评论(0) 收藏 举报
分类:

题目地址:http://poj.org/problem?id=2440

思路:先倒着推一下,然后再暴力打数据验证想法,最后找循环节为200就可以

a[n]表示长度为n的情况数,第n位只有0或1两种情况

当第n位为0时,前一位为0或1都可以,即a[n-1]

当第n位为1,n-1位为0时,则n-2位只能为0,n-3位任意取,即a[n-3],

当第n位为1,n-1位为1时,则n-2位只能为0,n-3位只能为0,n-4位任意取,即a[n-4]

a[n]=a[n-1]+a[n-3]+a[n-4]

AC代码:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <stack>
#include <map>
#include <cstring>
#include <climits>
#include <cmath>
#include <cctype>
const int inf = 0x3f3f3f3f;//1061109567
const int maxn = 1000010;
typedef long long LL;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
using namespace std;
int a[210];
void init()
{
    a[0] = 1;//注意要初始化a[0]
    a[1] = 2;
    a[2] = 4;
    a[3] = 6;
    a[4] = 9;
    for(int i=5; i<200; i++)
    {
        a[i] = (a[i-1] + a[i-3] + a[i-4]) % 2005;
    }
}
int main()
{
    init();
    int n;
    while(scanf("%d",&n) != EOF)
    {
        n %= 200;
        printf("%d\n",a[n]);
    }
    return 0;
}


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:118945次
    • 积分:5602
    • 等级:
    • 排名:第4860名
    • 原创:459篇
    • 转载:23篇
    • 译文:0篇
    • 评论:4条
    最新评论