码迷,mamicode.com
首页 > 编程语言 > 详细

vijos - P1077克隆龙 (找规律 + 指数型母函数 + python)

时间:2015-08-21 13:41:08      阅读:217      评论:0      收藏:0      [点我收藏+]

标签:

P1077克隆龙

描述

现在龙的克隆已成为可能,龙基因由ACTG字母组成,而龙的基因有如下特点:
1、A在基因中的出现为偶数次(包括0);
2、C的情况也一样;
当n=2时 满足条件的有6个:
TT,TG,GT,GG,AA,CC
你只需给出满足条件的基因数的最后两位数字即可;

格式

输入格式

输入文件给出了若干个n(1<=n<=10^9).最后以0结束。

输出格式

对于输入的n,满足条件的字符串的个数的最后两位数字!

样例1

样例输入1[复制]

1
2
3
0

样例输出1[复制]

2
6
20

来源

huyichen

找规律就可,指数型母函数稍后上传

这里的零应该进行特殊处理,比较坑

用python直接就是个递推式

技术分享

技术分享

#!/usr/bin/env python3
# -*- coding: utf-8 -*-


import math

import sys
for cin in sys.stdin:
    n = long(cin)
    if not n:break
    n -= 1
    a = math.ceil(pow(2, n, 100) * (pow(2, n, 100) + 1))
    a = long(a)
    if a % 100 == 0:
        print '00'
    else:
        print a % 100

C++:

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long LL;
int a[11] = {2,6,20,72,72,56,60,12,92,56};
int b[21] = {0,52,12,56,40,92,32,56,80,32,52,56,20,72,72,56,60,12,92,56};
int main() {
    int n;
    while(~ scanf("%I64d", &n),n) {
        if(n <= 10) {
            n -- ;
            printf("%d\n",a[n]);
        } else {
            if(b[(n - 11) % 20] == 0) printf("00\n");
            else printf("%d\n",b[(n - 11) % 20]);
        }

    }
    return 0;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

vijos - P1077克隆龙 (找规律 + 指数型母函数 + python)

标签:

原文地址:http://blog.csdn.net/qq_18661257/article/details/47832249

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!