10.18 T1

不是题目不会,而是思维方式有问题!!

1、Binary 

【题目描述】
求所有可以用1和00拼成的长度为N的二进制数的个数除以15746的余数。
比如当 N=4的时候,有5 个可能的二进制: 0011, 0000, 1001, 1100, 1111。
【输入文件】
第一行一个正整数 N;
【输出文件】
输出所有可以只用1和00拼成的长度为N的二进制数的个数除以15746的
余数。
【输入输出样例】
输入
4
输出
5
【数据规模】
在 100%的数据中,1<=N<=1000000。


1.这不是个数学题!!!不是组合数学;
2.知道想法不对后,依旧从数学入手进行推导,距离std越来越远;
3.这个题目是跳楼梯的变式,竟然看不出来(递推题目一共才做了几道);…

std

典型递推题目,对于已经从一到五都已经列出来了还看不出规律表示无语;

规律的推导

对于当前的一种状态,只需加1或00就可以成为一个新的合法字符串;
同理可证 ,当前的合法串一定是从以前的某个串转移过来的;
ps,也可参考跳楼梯
ntot
111
211, 002
3111 ,001 ,1113
41111, 0011 ,1001,0011,00005
511111, 00111 ,10011,11001,11100,00001,10000,001008
6………………….

? 你看不出这是斐波那契数列

#include<iostream>
#include<cstdio>
using namespace std;
long long n,ans=1;
const int mo=15746;
int main(){
    //freopen("binary.in","r",stdin);
    //freopen("binary.out","w",stdout);
    scanf("%d",&n);

    int a=2,b=1;
    if(n==2){
        printf("2");
        return 0;
    }
    for(int i=3;i<=n;i++)
    {
        ans=(a%mo+b%mo)%mo;
        b=a;
        a=ans;
    }
    printf("%d",ans);
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值