Carousel of Combinations

由圆排列的公式,不难有 C ( n , k ) = ( k n ) × k ! k C(n,k)=(_k^n)\times \frac{k!}{k} C(n,k)=(kn)×kk!

于是答案为 ∑ i = 1 n ∑ j = 1 i ( ( j i ) ⋅ ( j − 1 ) ! ) m o d   j \sum_{i=1}^{n}\sum_{j=1}^{i}((_j^i)\cdot (j-1)!)mod\space j i=1nj=1i((ji)(j1)!)mod j

显然交换求和次序,有 ∑ i = 1 n ∑ j = i n ( ( i j ) ⋅ ( i − 1 ) ! ) m o d   i \sum_{i=1}^{n}\sum_{j=i}^{n}((_i^j)\cdot (i-1)!)mod\space i i=1nj=in((ij)(i1)!)mod i

由威尔逊定理可将 i i i限定在质数和 4 4 4之中,再由卢卡斯定理(这个一定要手写写出来才会发现很容易化简,比赛的时候就觉得可以用程序去算就没有化简,从而导致根本没办法往下面做,所以以后遇到公式了一定要手写写出来)可化简为 ∑ i = 1 n ∑ j = i n ( ⌊ j i ⌋ ⋅ ( i − 1 ) ) m o d   i \sum_{i=1}^{n}\sum_{j=i}^{n}(\lfloor\frac{j}{i}\rfloor\cdot (i-1))mod\space i i=1nj=in(⌊ij(i1))mod i

补题的时候一直想的是每个 i i i对整体的贡献,但是题解告诉我们也可以考虑 i i i对特定局部的贡献,最后将所有局部汇总就好了

具体来说,这里反过去考虑 ∑ i = 1 n ∑ j = 1 i ( ( j i ) ⋅ ( j − 1 ) ! ) m o d   j \sum_{i=1}^{n}\sum_{j=1}^{i}((_j^i)\cdot (j-1)!)mod\space j i=1nj=1i((ji)(j1)!)mod j,设 d p [ i ] = ∑ j = 1 i ( ( j i ) ⋅ ( j − 1 ) ! ) m o d   j dp[i]=\sum_{j=1}^{i}((_j^i)\cdot (j-1)!)mod\space j dp[i]=j=1i((ji)(j1)!)mod j,再考虑 ∑ i = 1 n ∑ j = i n ( ⌊ j i ⌋ ⋅ ( i − 1 ) ) m o d   i \sum_{i=1}^{n}\sum_{j=i}^{n}(\lfloor\frac{j}{i}\rfloor\cdot (i-1))mod\space i i=1nj=in(⌊ij(i1))mod i,统计每个 i i i d p dp dp数组的贡献(枚举倍数利用差分),时间复杂度为 O ( n O(n O(n ln n ) n) n)

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-20 04:22:02       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-20 04:22:02       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-20 04:22:02       45 阅读
  4. Python语言-面向对象

    2024-07-20 04:22:02       55 阅读

热门阅读

  1. VUE Pinia和Vuex的比较

    2024-07-20 04:22:02       18 阅读
  2. 前端下载文件流 出现乱码 解决方案

    2024-07-20 04:22:02       17 阅读
  3. Odoo17应用、模型、字段

    2024-07-20 04:22:02       16 阅读
  4. Python使用distutils.version的StrictVersion比较版本大小

    2024-07-20 04:22:02       16 阅读
  5. GESP CCF C++ 八级认证真题 2024年6月

    2024-07-20 04:22:02       19 阅读
  6. C++ 前向声明

    2024-07-20 04:22:02       18 阅读
  7. Python-数据爬取(爬虫)

    2024-07-20 04:22:02       17 阅读
  8. 深入理解 Vue 3 组件通信

    2024-07-20 04:22:02       22 阅读
  9. 参考网站总结

    2024-07-20 04:22:02       21 阅读
  10. Spring注解开发

    2024-07-20 04:22:02       20 阅读
  11. C++ 数据结构

    2024-07-20 04:22:02       18 阅读