zoukankan      html  css  js  c++  java
  • [luogu5438]记忆

    令$f(x)=frac{x}{max_{k^{2}|x}k^{2}}$,最优解即将$f(l),f(l+1),...,f(r)$排序,那么每存在一种不同的数则答案减1,那么$x$出现当且仅当$f(x)=x$且存在$k$满足$lle xk^{2}le r$

    枚举$k$,那么即求$(lfloorfrac{l-1}{k^{2}} floor,lfloorfrac{r}{k^{2}} floor]$中有多少个数最大平方因子为1,但同时还有重复,即区间右端点要对上一次左端点取min,之后拆成两个前缀和,即求$[1,n]$中$f(x)=x$的数个数

    类似洛谷4318,容斥即$sum_{i=1}^{sqrt{n}}mu(i)lfloorfrac{n}{i^{2}} floor$,再对$i$数论分块,对于$ile n^{frac{1}{3}}$,共$o(n^{frac{1}{3}})$种;对于$i>n^{frac{1}{3}}$,则有$frac{n}{i^{2}}le n^{frac{1}{3}}$,同样共$o(n^{frac{1}{3}})$种

    再对外层$k$数论分块,对于较小的一部分直接线性筛求出$mu$,对于较大的部分套用上面的做法,考虑复杂度:对于$kle r^{x}$,复杂度为$r^{frac{1}{3}}int_{0}^{r^{x}}k^{-frac{2}{3}} dk=o(r^{frac{x+1}{3}})$;对于$k>r^{x}$,则有$frac{r}{k^{2}}le r^{1-2x}$,复杂度为$o(r^{1-2x})$

    取$frac{x+1}{3}=1-2x$,解得$x=frac{2}{7}$,总复杂度为$o(r^frac{3}{7})$,可以通过

     1 #include<bits/stdc++.h>
     2 using namespace std;
     3 #define N 10000005
     4 #define ll long long
     5 int p[N],vis[N],mu[N],s1[N],s2[N];
     6 ll l,r,ans;
     7 ll calc(ll n){
     8     if (n<N-4)return s2[n];
     9     ll ans=0;
    10     for(ll i=1,j;i*i<=n;i=j+1){
    11         j=(ll)sqrt(n/(n/(i*i)));
    12         ans+=n/(i*i)*(s1[j]-s1[i-1]);
    13     }
    14     return ans;
    15 }
    16 int main(){
    17     mu[1]=1;
    18     for(int i=2;i<N-4;i++){
    19         if (!vis[i]){
    20             p[++p[0]]=i;
    21             mu[i]=-1;
    22         }
    23         for(int j=1;(j<=p[0])&&(i*p[j]<N-4);j++){
    24             vis[i*p[j]]=1;
    25             if (i%p[j])mu[i*p[j]]=mu[i]*mu[p[j]];
    26             else{
    27                 mu[i*p[j]]=0;
    28                 break;
    29             }
    30         }
    31     }
    32     for(int i=1;i<N-4;i++){
    33         s1[i]=s1[i-1]+mu[i];
    34         s2[i]=s2[i-1]+mu[i]*mu[i];
    35     }
    36     scanf("%lld%lld",&l,&r);
    37     l--;
    38     ans=r-l;
    39     ll las=r;
    40     for(ll i=1,j;i*i<=r;i=j+1){
    41         if (i*i>l)j=(ll)sqrt(r/(r/(i*i)));
    42         else j=(ll)sqrt(min(l/(l/(i*i)),r/(r/(i*i))));
    43         ans-=calc(min(r/(i*i),las))-calc(l/(i*i));
    44         las=l/(i*i);
    45     }
    46     printf("%lld",ans);
    47 }
    View Code
  • 相关阅读:
    mapreduce 函数入门 二
    mapreduce 函数入门 一
    Flume+Kafka+Storm+Redis 大数据在线实时分析
    mapReduce 大数据离线分析
    docker 简介
    flume安装使用+根据数据源分类
    hiho 171周
    如何新建一个空的optix工程
    读 Real-Time Rendering 收获
    hiho 1590
  • 原文地址:https://www.cnblogs.com/PYWBKTDA/p/13960932.html
Copyright © 2011-2022 走看看