原题:  Turn the pokers
      思路:假设正面为0,反面为1。牌就像这样 000000....... 。考虑到假如可以实现最终反面个数为m, 牌共n张, 则这n张排任取m个为反面其余都为正面的状况都能实现。于是转化为考虑最终可能出现1的个数的集合有哪些。
      因为可能的个数集合是连续的(在最大最小值之内相差2的都可能), 所以每一次翻转之后的上下限都可以根据上一次所得的上下限推出。
      最后算排列组合的适合需要用到组合数递推公式和费马小定理推论\( a^{p-2} \equiv a^{-1} \bmod p \) , 通过快速幂的方法算一下逆元。

其实TLE了n次。。。。。。用位运算简化了一下。。。而且输入那个部分要用scanf才够快。

  1 #include <iostream>

  2 #include <fstream>

  3 #include <cstring>

  4 #include <cstdio>

  5 #include <algorithm>

  6 #include <cmath>

  7 //#define LOCAL

  8 #define fin cin

  9 #define fout cout

 10 #define LL long long int

 11 #define maxn 100000+5

 12 using namespace std;

 13 LL MM=;

 14 LL C[maxn];

 15 LL quickmod(LL a,int b)

 16 {

 17    LL ans=,base=a;

 18 

 19    while(b!=)

 20    {

 21      if(b&)

 22      {

 23         ans=ans*base%MM;

 24     }

 25     b>>=;

 26     base=base*base%MM;

 27 }

 28 

 29 return ans;

 30 }

 31 int main ()

 32 {

 33 #ifdef LOCAL

 34     ofstream fout ("1.out");

 35     ifstream fin ("1.in");

 36 #endif

 37 

 38     int i,j,k;

 39     int n,m,x;

 40 

 41     memset(C,,sizeof(C));

 42 

 43     while(fin>>n>>m)

 44     {

 45 

 46         int left,right,a1,a2;

 47         left=; right=;

 48 

 49         for(i=;i<n;i++)

 50         {

 51             scanf("%d",&x);

 52 

 53 

 54             if(x<=left){ a1=left-x; }

 55             else if(x<=right)

 56                 {   a1= ((left&)==(x&))?:;

 57                 }

 58                 else{

 59                     a1=x-right;

 60                 }

 61 

 62                 if(x<=m-right){ a2=right+x; }

 63                 else if(x<=m-left)

 64                 {

 65                     a2 = (((m-left)&) == (x&)?m:m-);

 66                 }

 67                 else{

 68                     a2=*m-(x+left);

 69                 }

 70 

 71                 left=a1;right=a2;

 72 

 73             }

 74 

 75 

 76             C[]=; C[m]=;

 77 

 78             for(i=;i<=m/+;i++)

 79                 {C[i]=C[i-]*(m-i+)%MM*quickmod(i,MM-)%MM;

 80 

 81                    C[m-i]=C[i];

 82                }

 83 

 84 

 85                LL sum = ;

 86                for(i = left; i<=right; i+=)

 87                 { sum+=C[i];

 88                   sum%=MM;

 89               }

 90 

 91               fout<<sum<<endl;

 92           }

 93 

 94 

 95 #ifdef LOCAL

 96           fin.close();

 97           fout.close();

 98 #endif

 99 

           return ;} 

HDU-4869 Turn the pokers的更多相关文章

  1. HDU 4869 Turn the pokers(推理)

    HDU 4869 Turn the pokers 题目链接 题意:给定n个翻转扑克方式,每次方式相应能够选择当中xi张进行翻转.一共同拥有m张牌.问最后翻转之后的情况数 思路:对于每一些翻转,假设能确 ...

  2. hdu 4869 Turn the pokers (2014多校联合第一场 I)

    Turn the pokers Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  3. HDU 4869 Turn the pokers(思维+组合公式+高速幂)

    pid=4869" target="_blank">Turn the pokers 大意:给出n次操作,给出m个扑克.然后给出n个操作的个数a[i],每一个a[i] ...

  4. HDU 4869 Turn the pokers (2014 Multi-University Training Contest 1)

    Turn the pokers Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  5. hdu 4869 Turn the pokers (思维)

    Turn the pokers Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  6. HDU 4869 Turn the pokers (2014多校联合训练第一场1009) 解题报告(维护区间 + 组合数)

    Turn the pokers Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  7. hdu 4869 Turn the pokers(组合数+费马小定理)

    Problem Description During summer vacation,Alice stay at home for a long time, with nothing to do. S ...

  8. HDU 4869 Turn the pokers (2014 多校联合第一场 I)

    HDOJ--4869--Turn the pokers[组合数学+快速幂] 题意:有m张扑克,开始时全部正面朝下,你可以翻n次牌,每次可以翻xi张,翻拍规则就是正面朝下变背面朝下,反之亦然,问经过n次 ...

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

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

  10. HDU 4869 Turn the pokers(思维+逆元)

    考试的时候没有做出来... 想到了答案一定是一段连续的区间,一直在纠结BFS判断最后的可行1数. 原来直接模拟一遍就可以算出来最后的端点... 剩下的就是组合数取模了,用逆元就行了... # incl ...

随机推荐

  1. C#获取程序集自动增加的版本号和编译时间

    1. 首先找到文件AssemblyInfo.cs, 路径如下: 2. 修改版本的格式,修改后,程序每次编译,程序集的版本号都会自增. 修改前: [assembly: AssemblyVersion(& ...

  2. Java(异常处理)动手动脑

    1>请阅读并运行AboutException.java示例,然后通过后面的几页PPT了解Java中实现异常处理的基础知识. import javax.swing.*; class AboutEx ...

  3. A*寻路算法(JavaScript实现)

    参考资料:http://www.cnblogs.com/zhoug2020/p/3468167.html               http://www.cnblogs.com/lipan/arch ...

  4. Oracle Cursor

    1.概念 游标:从字面来理解就是游动的光标.用数据库语言来描述,游标是映射在结果集中一行数据上的位置实体,有了游标,用户就可以访问结果集中的任意一行数据了.将游标放置到某行后,即可对该行数据进行操作, ...

  5. iava多线程详解(2)-成员变量与局部变量访问

    有两段代码 1.线程访问成员变量 public class FirstThreadTest { public static void main(String[] args) { FirstThread ...

  6. 空MVC项目找不到System.Web.Optimization的处理办法

    install-package Microsoft.AspNet.Web.Optimization Create the bundle in Global.asax Application_Start ...

  7. SQL server 动态行转列

    用聚合函数配合CASE语句实现行转列功能: 现在分享一下具体实现代码: 转换前效果: PlanName PlanType PlanLimit 计划1 计划类型1 RMB 1,000,000 计划1 计 ...

  8. app开发遇到问题及解决

    1:ios and Android 差异input type=text 当用户点击input框时,弹出手机键盘,ios会遮挡输入框 解决办法: pswOnFocus = function(){ tar ...

  9. asp.net运行时错误:没有为扩展名".cshtml"注册的提供程序。

    解决方法: 一.  在machine.config或web.config中的<compilation><buildProviders>节注册一个.请确保所注册的提供程序具有包含 ...

  10. 高性能 CSS3 动画

    注:本文出自腾讯AlloyTeam的元彦,文章也可以在github上浏览.请尊重版权,转载请注明来源,多谢-- 高性能移动Web相较PC的场景需要考虑的因素也相对更多更复杂,我们总结为以下几点: 流量 ...