题目链接http://acm.hdu.edu.cn/showproblem.php?pid=4704

这个题很刁是不是,一点都不6,为什么数据范围要开这么大,把我吓哭了,我kao......说笑的,哈哈。

一开始题意没看清(老毛病了),然后就以为用N对1e+9取模,因为给的数的范围为10100000

所以只能开数组模拟。错了一发。后来再看题,发现错了,S(n)代表的是将N分成n个数的合的不同种类。

那么求S(n)的方法就是高中数学老师教的隔板法,有点忘了。隔板法是这样的,如果N为5,那么将5写成5个1隔开,就像这样

1 1 1 1 1,顾名思义隔板法就是在中间空格出放板子,现在最左和最右边放个板子,不是空格出。如过要求S(3);那么就在4个空格中找2个放格子,那么每两块板子

间的1加起来就是所分的数字,比如放在第格和第二格,分的就为1 1 3,而所CN3

就是S(3);那么可的通项Cnk

那么S(1)+S(2)+S(3)+....S(N)=2N-1

所以就是求2N-1(mod)(1e+7);

因为N-1很大所以可以用费马小定理;

费马小定理在p为素数的情况下对任意的整数x都有x^p==x(mod p)

;如果x不能被p整除有x^(p-1)=1(mod p);由于a,b<1e9;所以不能被1e9+7整除, 求出了k[n],则a^k[n]%p=a^(k[n]%(p-1))%p;

证明如下: k[n]=m*(p-1)+d;那么a^k[n]%p=a^[(m*(p-1))+d]%p=(a^[m*(p-1)]%p*a^(d)%p)%p;

由费马小定理可知a^(m*(p-1))%p=1; 而d=k[n]%(p-1);得证;

然后再快速幂就行了。

 1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<stdlib.h>
5 #include<string.h>
6 typedef long long ll;
7 ll fastmi(ll n);
8 using namespace std;
9 ll a[100100];
10 char b[100005];
11 ll c[100100];
12 ll k[100100];
13 const int N=1e9+7;
14 const int M=1e9+6;
15 int main(void)
16 {
17 k[0]=5;
18 k[1]=0;
19 k[2]=0;
20 k[3]=0;
21 k[4]=0;
22 k[5]=0;
23 k[6]=0;
24 k[7]=0;
25 k[8]=0;
26 k[9]=1;
27 ll n,i,j,p,q,l;
28 while(scanf("%s",b)!=EOF)
29 {
30 memset(a,0,sizeof(a));
31 l=strlen(b);
32 ll t=1;
33 for(i=0; i<l; i++)
34 {
35 a[i]=b[l-i-1]-'0';
36 }
37
38 int uu=0;
39 for(i=0; i<l+20; i++)
40 {
41
42
43 a[i]=k[i]+a[i]+uu;
44 uu=a[i]/10;
45 a[i]=a[i]%10;
46 }
47
48 ll ww=1;
49 ll pp=0;
50 for(i=0; i<l+20; i++)
51 {
52 pp=(pp%M+(ww%M*a[i]%M)%M)%M;
53 ww=(ww%M*10%M)%M;
54
55 }//(N-1)modM=(N-1+M)modM,为1e+6;M-1为1e+5;k[]数组存的就为1e+5;
56 ll dd=fastmi(pp);
57 printf("%lld\n",dd);
58 }
59
60 return 0;
61
62
63 }
64
65 ll fastmi(ll n)//快速幂
66 {
67 ll x=1;
68 ll y=2;
69 while(n)
70 {
71 if(n&1)
72 {
73 x=(x%N*y%N)%N;
74 }
75 y=(y%N*y%N)%N;
76 n=n/2;
77 }
78 return x;
79 }

hdu 4704 Sum(组合,费马小定理,快速幂)的更多相关文章

  1. HDU 4704 Sum( 费马小定理 + 快速幂 )

    链接:传送门 题意:求 N 的拆分数 思路: 吐嘈:求一个数 N 的拆分方案数,但是这个拆分方案十分 cd ,例如:4 = 4 , 4 = 1 + 3 , 4 = 3 + 1 , 4 = 2 + 2 ...

  2. hdu 4704 sum(费马小定理+快速幂)

    题意: 这题意看了很久.. s(k)表示的是把n分成k个正整数的和,有多少种分法. 例如: n=4时, s(1)=1     4 s(2)=3     1,3      3,1       2,2 s ...

  3. hdu 4704 Sum 【费马小定理】

    题目 题意:将N拆分成1-n个数,问有多少种组成方法. 例如:N=4,将N拆分成1个数,结果就是4:将N拆分成2个数,结果就是3(即:1+3,2+2,3+1)--1+3和3+1这个算两个,则这个就是组 ...

  4. HDU 4704 Sum(隔板原理+组合数求和公式+费马小定理+快速幂)

    题目传送:http://acm.hdu.edu.cn/showproblem.php?pid=4704 Problem Description   Sample Input 2 Sample Outp ...

  5. 数论 --- 费马小定理 + 快速幂 HDU 4704 Sum

    Sum Problem's Link:   http://acm.hdu.edu.cn/showproblem.php?pid=4704 Mean: 给定一个大整数N,求1到N中每个数的因式分解个数的 ...

  6. hdu 4704(费马小定理+快速幂取模)

    Sum                                                                                Time Limit: 2000/ ...

  7. 2014多校第一场 I 题 || HDU 4869 Turn the pokers(费马小定理+快速幂模)

    题目链接 题意 : m张牌,可以翻n次,每次翻xi张牌,问最后能得到多少种形态. 思路 :0定义为反面,1定义为正面,(一开始都是反), 对于每次翻牌操作,我们定义两个边界lb,rb,代表每次中1最少 ...

  8. hdu_4869(费马小定理+快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4869 Turn the pokers Time Limit: 2000/1000 MS (Java/O ...

  9. BZOJ_[HNOI2008]_Cards_(置换+Burnside引理+乘法逆元+费马小定理+快速幂)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1004 共n个卡片,染成r,b,g三种颜色,每种颜色的个数有规定.给出一些置换,可以由置换得到的 ...

  10. hdu4549(费马小定理 + 快速幂)

    M斐波那契数列F[n]是一种整数数列,它的定义如下: F[0] = a F[1] = b F[n] = F[n-1] * F[n-2] ( n > 1 ) 现在给出a, b, n,你能求出F[n ...

随机推荐

  1. CMSIS-RTOS 信号量Semaphores

    信号量Semaphores 和信号类似,信号量也是一种同步多个线程的方式,简单来讲,信号量就是装有一些令牌的容器.当一个线程在执行过程中,就可能遇到一个系统调用来获取信号量令牌,如果这个信号量包含多个 ...

  2. C语言中的各种类型所占的字节大小

    一)64位系统和32位有什么区别?  1.64bit CPU拥有更大的寻址能力,最大支持到16GB内存,而32bit只支持4G内存 2.64位CPU一次可提取64位数据,比32位提高了一倍,理论上性能 ...

  3. three.js很好玩

    能用鼠标拉着转. https://files.cnblogs.com/files/blogs/714801/%E7%A9%BA%E9%97%B4%E5%87%A0%E4%BD%95.7z var po ...

  4. flink---实时项目----day03---1.练习讲解(全局参数,数据以parquet格式写入hdfs中) 2 异步查询 3 BroadcastState

    1 练习讲解(此处自己没跑通,以后debug) 题目见flink---实时项目---day02 kafka中的数据,见day02的文档 GeoUtils package cn._51doit.flin ...

  5. 【排序算法】——冒泡排序、选择排序、插入排序、Shell排序等排序原理及Java实现

    排序 1.定义: 所谓排序,即是整理文件中的内容,使其按照关键字递增或递减的顺序进行排列. 输入:n个记录,n1,n2--,其对应1的关键字为k1,k2-- 输出:n(i1),n(i2)--,使得k( ...

  6. Java文件操作(求各专业第一名的学生)

    两个文件:info.txt 存放学生基本信息 学号 学院 专业 姓名 1001 计算机学院 软件工程 刘月 1002 生物工程 服装设计 孙丽 score.txt存放分数信息 学号 学科 成绩 100 ...

  7. OpenStack之四: keystone验证服务(端口5000)

    #官网地址:https://docs.openstack.org/keystone/stein/install/keystone-install-rdo.html #:创建库,并授权 MariaDB ...

  8. Spring Boot中使用Mybatis

    一.步骤 导入依赖:MySQL驱动.Druid依赖.MyBatis与Spring Boot整合依赖.Lombok依赖 在Service接口实现类上添加@Service注解 在Dao接口上添加@Mapp ...

  9. 【spring AOP】AspectJProxyFactory

    AspectJProxyFactory,可能大家对这个比较陌生,但是@Aspect这个注解大家应该很熟悉吧,通过这个注解在spring环境中实现aop特别的方便. 而AspectJProxyFacto ...

  10. 🏆【Alibaba中间件技术系列】「RocketMQ技术专题」Broker配置介绍及发送流程、异常(XX Busy)问题分析

    参考资料 Rocketmq官网:http://rocketmq.apache.org/ Rocketmq的其它项目:https://github.com/apache/rocketmq-externa ...