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

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;
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值