//整除分块,n版
ll aliquot_patition(int n) {
    ll ans=0;
    for(int l=1,r; l<=n; l=r+1) {
        r=n/(n/l);
        ans+=1ll*(n/l)*(sum[r]-sum[l-1]);
    }
    return ans;
}


//整除分块,n,m版
ll aliquot_patition(int n,int m) {
    ll ans=0;
    int N=min(n,m);
    for(int l=1,r; l<=N; l=r+1) {
        r=min(n/(n/l),m/(m/l));
        ans+=1ll*(n/l)*(m/l)*(sum[r]-sum[l-1]);
    }
    return ans;
}

其中sum是指前缀和,而不是别的什么约数的莫比乌斯函数之和之类的.

相关文章:

  • 2022-03-06
  • 2021-10-04
  • 2021-10-25
  • 2021-09-21
  • 2021-11-17
  • 2021-07-22
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-02-23
  • 2021-06-17
  • 2022-12-23
  • 2021-12-22
相关资源
相似解决方案