zoukankan      html  css  js  c++  java
  • Luogu1445 [Violet]樱花 数论优化

    Luogu1445 [Violet]樱花

    一句话题意:(本来就是一句话的)

    求方程 $\frac{1}{X} + \frac{1}{Y} = \frac{1}{N!}$ 的正整数解的组数,其中$N \leq 10^6$

    题解:

    差不多是第一篇公开的题解,因为以前的太烂了,不敢发......

    我们观察到提交记录发现似乎时间有从200ms+到8ms-的,然而标准题解中给出的代码就是跑的比较慢的......

    所以有没有什么快一点的呢?

    假设此时你已经用朴素算法A过此题

    于是我们分析算法:

    楼下题解的复杂度是$O(nlogn+常数的)$,平均200ms

    有没有什么更快的呢?

    假设我们分析到了

    $A*B=(n!)*(n!)$

    的时候发现最终求的就是约数个数

    首先如果求m的约数个数的话,那么对m分解得到

    $m=p_1^{k_1}*p_2^{k_2}...$

    其中$p_1,p_2,p_3...$都是质数

    那么根据乘法原理

    $Ans = (k_1 + 1) * (k_2 + 1)...$

    然后对于阶乘来说,对n!做质因数分解实则在分解1 * 2 * ... * n

    然而这个就是朴素的做法,然而由于你实则是需要求质因数的指数,而在《初等数论》中有

    $\Sigma(p \leq n, p \  is \  a \  prime)\Sigma_{k=0}^{p^k \leq n}(\lfloor \frac{n}{p^k} \rfloor)$

    所以我们直接递归(或者非递归地)跑这个公式即可

    实际食用:枚举质数(或打表)(在阶乘下质因数等价于质数)(O(n)),然后对于所有质数,跑公式。

    n内大约有n/ln(n)个质数,然后每次做都是log的,所以复杂度为O(n/ln(n) * log(n))=O(n),常数小,瓶颈在筛质数那......

    代码如下:

     1 //Source Code
     2 
     3 const int MAXN = 1000111;
     4 const int MODS = 1000000007;
     5 
     6 int n, tot;
     7 int prime[MAXN];
     8 bool is_not_prime[MAXN];
     9 
    10 inline void Get_Prime(){
    11     for(int i = 2; i <= n; i++){
    12         if(!is_not_prime[i])
    13             prime[++tot] = i;
    14         for(int j = 1; j <= tot; j++){
    15             if(i * prime[j] > n) break;
    16             is_not_prime[i * prime[j]] = true;
    17             if(!(i % prime[j])) break;
    18         }
    19     }
    20 }
    21 
    22 inline int Get_D(const int &tar, const int &p){
    23     if(tar < p) return 0;
    24     return tar / p + Get_D(tar / p, p);
    25 }
    26 
    27 int main(){
    28     Main_Init();
    29     n = read();
    30     Get_Prime();
    31     long long ans = 1;
    32     for(int i = 1; i <= tot; i++)
    33         (ans *= (Get_D(n, prime[i]) << 1) + 1) %= MODS;
    34     write('\n', ans);
    35     Main_Init();
    36     return 0;
    37 }
    我永远爱19491001
  • 相关阅读:
    Linux防火墙白名单设置
    postgre级联更新
    postgre查询表和记录数,查表字段
    PostgreSQL中的 时间格式转化常识
    android 阿里云oss上传
    android studio connot resolve
    Mysql 优化,慢查询
    Docker 容器更新,打包,上传到阿里云
    Mysql 替换字段的一部分内容
    Docker 安装Nginx
  • 原文地址:https://www.cnblogs.com/CreeperLKF/p/9004693.html
Copyright © 2011-2022 走看看