• 洛谷 Array 数论


    题目:

    对于长度为n的数组A,A中只包含从1到n的整数(可重复)。如果A单调不上升或单调不下降,A就可称为美丽的。 找出在长度为n时,有几个美丽的A。


    思路:

    这是一道数论题。

    我们先找找“单调不递减的A”

    1.构造模型:设一个长度为(2*n-1)的序列,用1填满n个空,剩余(n-1)个空;

    2.一一对应:找到每一个“1”,用其前方总共的“空格数”构成新序列。如下图所示。

    7d9bc7f62cff49389e9b55fd7cb138c5.jpg

     

     

    3.合理性:构成的序列满足两个条件。

    • (1)不递减:因为空格的数目只会累加。(如果两个“1”相邻的话会出现新序列中有相同数字的情况)
    • (2)新序列中每个数字都是0到n-1的整数(可重复)对应题干中“从1到n的整数”:因为空格的数目最多只有n-1。

    可见,单调不递减的A的数目=eq?%5Cbinom%7Bn%7D%7B2*n-1%7D

    易得,单调不递增的A的数目=单调不递减的A的数目=eq?%5Cbinom%7Bn%7D%7B2*n-1%7D

    所以,由容斥定理得,答案=不递增+不递减-既不递增.也不递减(常数序列)                                                                             eq?%3D%202%5Ccdot%20%5Cbinom%7Bn%7D%7B2*n-1%7D-n%3D%20%5Cbinom%7Bn%7D%7B2*n%7D-n.


    代码展示:

    1. #include<stdio.h>
    2. #include<stdlib.h>
    3. const int mod=1000000007;
    4. long long ny(long long x)//逆元 取模
    5. {
    6. int cf=mod-2;long long base=x,ans=1;
    7. while(cf)
    8. {
    9. if(cf%2==1) ans*=base;
    10. ans%=mod;
    11. base=base*base;
    12. base%=mod;
    13. cf>>=1;
    14. }
    15. return ans;
    16. }
    17. long long c(int x,int y)//计算组合数
    18. {
    19. long long fz=1,fm=1,ans;int i;
    20. for(i=x;i>=x-y+1;i--)
    21. {
    22. fz*=i;
    23. fz%=mod;
    24. }
    25. for(i=1;i<=y;i++)
    26. {
    27. fm*=i;
    28. fm%=mod;
    29. }
    30. fm=ny(fm);
    31. ans=fz*fm;
    32. ans%=mod;
    33. return ans;
    34. }
    35. long long zj;
    36. int main()
    37. {
    38. //答案是c(2n,n)-n
    39. int n,i;
    40. scanf("%d",&n);
    41. zj=c(2*n,n);
    42. zj-=n;
    43. if(zj<0) zj+=mod;
    44. printf("%lld",zj);
    45. return 0;
    46. }

     

     

     

  • 相关阅读:
    【科技素养】蓝桥杯STEMA 科技素养组模拟练习试卷C
    如何购买并配置华为云服务器?
    Set集合(超详解)
    Linux字符设备驱动开发(二)
    C++中sort()函数的greater<int>()参数
    进程互斥以及进程互斥实现方法(包含代码)
    Jquery
    (学习日记)2022.7.26
    抖 X-Bongus 参数逆向 python案例实战
    MongoDB 开源“可查询加密”系统 Queryable Encryption
  • 原文地址:https://blog.csdn.net/2302_76169191/article/details/132747786