• hdu 4704 Sum【组合数学/费马小定理/大数取模】By cellur925


    首先,我们珂以抽象出S函数的模型:把n拆成k个正整数,有多少种方案?

    答案是C(n-1,k-1)。

    然后发现我们要求的是一段连续的函数值,仔细思考,并根据组合数的性质,我们珂以发现实际上答案就是在让求2^(n-1)。

    然鹅我们并不能高兴地过早。因为n的数量级竟然到了丧心病狂的1e100000.连高精度都救不了它

    费马小定理

    费马小定理有两种形式:  $a^{p-1}$≡1($mod$ $p$)   与 $a^p$≡$a$($mod$ $p$)。 第二种形式更为通用,是因为第一种形式不能涵盖“$a$是$p$的倍数”的情况,不够完善。第二种更加严谨。

     *  Update:其实这是扩展欧拉定理。思考了一上午后来被大佬告知这是一个定理...

    定理可戳这位大佬的文章

    那么对于本题。我们就求$2^{{n-1}%{p-1}}%p$就行了...还要大数取膜...恶心。

    $Code$

     1 #include<cstdio>
     2 #include<algorithm>
     3 #include<cstring>
     4 
     5 using namespace std;
     6 typedef long long ll;
     7 const ll moder=1e9+7;
     8 
     9 char seq[200000];
    10 
    11 ll ksm(ll a,ll b)
    12 {
    13     ll ans=1;
    14     while(b)
    15     {
    16         if(b&1) ans=ans*a%moder;
    17         b>>=1;
    18         a=a*a%moder;
    19     }
    20     return ans;
    21 }
    22 
    23 int main()
    24 {
    25     while(scanf("%s",seq+1)!=EOF)
    26     {
    27         ll m=moder-1;
    28         ll tmp=0;
    29         int len=strlen(seq+1);
    30         for(int i=1;i<=len;i++)
    31         {
    32             tmp=tmp*10+seq[i]-'0';
    33             if(tmp>=m) tmp=tmp%m;
    34         }
    35         tmp=(tmp-1+m)%m;
    36         printf("%lld
    ",ksm(2,tmp));
    37     }
    38     return 0;
    39 }
    View Code

     

  • 相关阅读:
    PHP远程下载图片,微信头像存到本地,本地图片转base64
    jQuery Validate自定义错误信息,自定义方法
    创建自己的composer包
    js,JQ获取短信验证码倒计时
    JQ JS复制到剪贴板
    js,JQuery 生成二维码
    js,JQuery实现,带筛选,搜索的select
    HTML5拖放牛刀小试
    HTML5上传图片预览功能
    一次dropzone体验
  • 原文地址:https://www.cnblogs.com/nopartyfoucaodong/p/9716258.html
Copyright © 2020-2023  润新知