题意

求\(\sum_{i=1}^{n}\varphi(i)和\sum_{i=1}^{n}\mu(i)\)

\(n <= 2^{31}-1\)

不会做啊。。。

只会线性筛,显然不能线性筛

这个时候就需要杜教筛

怎么筛

先看一下狄利克雷卷积

假设我们要求\(F(i)=\sum_{i=1}^{n}f(n)\)而\(n(10^{11}左右)\)比较大不能线性筛时考虑杜教筛

套路的推导:

先随意找一个函数\(g(i)\)和\(f(i)\)求狄利克雷卷积:

$$(g * f)(n) = \sum_{d|n} g(d)f(\frac{n}{d})$$

它的前缀和就是

$$\sum_{i=1}^{n}\sum_{d|i} g(d)f(\frac{i}{d})$$

现在要想办法向\(F(n)\)上靠:

$$原式=\sum_{d=1}{n}\sum_{d|i}g(d)f(\frac{i}{d})=\sum_{d=1}{n}\sum_{i=1}^{\lfloor\frac{n}{d}\rfloor}g(d)f(i)$$

$$=\sum_{d=1}{n}g(d)\sum_{i=1}{\lfloor\frac{n}{d}\rfloor}f(i)=\sum_{d=1}^{n}g(d)F(\lfloor\frac{n}{d}\rfloor)$$

所以

\[g(1)F(n)=(g * f)(n)-\sum_{d=2}^{n}g(d)F(\lfloor\frac{n}{d}\rfloor)
\]

\(g(1)=1时最好\)

如果能够快速的对\(g\)和\(g * f\)求和,那么就能在\(O(n^{\frac{3}{4}})的时间内计算出F(n)\)复杂度证明略不会

如果\(f\)为积性函数,还可以线性筛出\(F\)的前若干项(\(n^{\frac{2}{3}}\)最优)降低复杂度

Sol

再看这道题

先看\(\varphi\):

设\(\phi(i)=\sum_{i=1}^{n}\varphi(i)\)

按上面的来

$$g(1)\phi(n)=\sum_{i=1}{n}(g*\varphi)(i)-\sum_{i=2}{n}g(d)\phi(\lfloor\frac{n}{d}\rfloor)$$

有个定理\(\sum_{d|n}\varphi(d)=n\)

设\(g(i)=1\)所以

$$\sum_{i=1}{n}(g*\varphi)(i)=\sum_{i=1}{n}\sum_{d|i}\varphi(\frac{i}{d})=\frac{n*(n + 1)}{2}$$

线性筛一部分,带进去递归处理即可

再看\(\mu\):

设\(U(n)=\sum_{i=1}^{n}\mu(i)\)

一样的套路得到

$$g(1)U(n)=\sum_{i=1}{n}\sum_{d|i}g(d)\mu(\frac{i}{d})-\sum_{i=2}{n}g(d)U(\lfloor\frac{n}{d}\rfloor)$$

注意到\(\sum_{d|n}\mu(d)=[n=1]\),直接令\(g(i)=1\)则

$$U(n)=1-\sum_{i=2}^{n}g(d)U(\lfloor\frac{n}{d}\rfloor)$$

一样的递归处理即可

一定要记忆化(我用的map)

# include <bits/stdc++.h>
# define RG register
# define IL inline
# define Fill(a, b) memset(a, b, sizeof(a))
using namespace std;
typedef long long ll;
const int _(5e6 + 1); IL ll Read(){
RG ll x = 0, z = 1; RG char c = getchar();
for(; c < '0' || c > '9'; c = getchar()) z = c == '-' ? -1 : 1;
for(; c >= '0' && c <= '9'; c = getchar()) x = (x << 1) + (x << 3) + (c ^ 48);
return x * z;
} int prime[_], num;
ll phi[_], mu[_];
map <int, ll> Phi, Mu;
bool isprime[_]; IL void Prepare(){
isprime[1] = 1; phi[1] = mu[1] = 1;
for(RG int i = 2; i < _; ++i){
if(!isprime[i]){ prime[++num] = i; mu[i] = -1; phi[i] = i - 1; }
for(RG int j = 1; j <= num && i * prime[j] < _; ++j){
isprime[i * prime[j]] = 1;
if(i % prime[j]){ mu[i * prime[j]] = -mu[i]; phi[i * prime[j]] = phi[i] * (prime[j] - 1); }
else{ mu[i * prime[j]] = 0; phi[i * prime[j]] = phi[i] * prime[j]; break; }
}
}
for(RG int i = 2; i < _; ++i) mu[i] += mu[i - 1], phi[i] += phi[i - 1];
} IL ll Sumphi(RG ll n){
if(n < _) return phi[n];
if(Phi[n]) return Phi[n];
RG ll ans = n * (n + 1) / 2;
for(RG ll i = 2, j; i <= n; i = j + 1){
j = n / (n / i);
ans -= (j - i + 1) * Sumphi(n / i);
}
return Phi[n] = ans;
} IL ll Summu(RG ll n){
if(n < _) return mu[n];
if(Mu[n]) return Mu[n];
RG ll ans = 1;
for(RG ll i = 2, j; i <= n; i = j + 1){
j = n / (n / i);
ans -= (j - i + 1) * Summu(n / i);
}
return Mu[n] = ans;
} int main(RG int argc, RG char* argv[]){
Prepare();
for(RG int T = Read(); T; --T){
RG ll n = Read();
printf("%lld %lld\n", Sumphi(n), Summu(n));
}
return 0;
}

杜教筛:Bzoj3944: sum的更多相关文章

  1. 杜教筛 && bzoj3944 Sum

    Description Input 一共T+1行 第1行为数据组数T(T<=10) 第2~T+1行每行一个非负整数N,代表一组询问 Output 一共T行,每行两个用空格分隔的数ans1,ans ...

  2. LG4213 【模板】杜教筛(Sum)和 BZOJ4916 神犇和蒟蒻

    P4213 [模板]杜教筛(Sum) 题目描述 给定一个正整数$N(N\le2^{31}-1)$ 求 $$ans_1=\sum_{i=1}^n\varphi(i)$$ $$ans_2=\sum_{i= ...

  3. [洛谷P4213]【模板】杜教筛(Sum)

    题目大意:给你$n$,求:$$\sum\limits_{i=1}^n\varphi(i),\sum\limits_{i=1}^n\mu(i)$$最多$10$组数据,$n\leqslant2^{31}- ...

  4. Luogu 4213 【模板】杜教筛(Sum)

    当作杜教筛的笔记吧. 杜教筛 要求一个积性函数$f(i)$的前缀和,现在这个东西并不是很好算,那么我们考虑让它卷上另外一个积性函数$g(i)$,使$(f * g)$的前缀和变得方便计算,然后再反推出这 ...

  5. P4213 【模板】杜教筛(Sum)

    \(\color{#0066ff}{题 目 描 述}\) 给定一个正整数\(N(N\le2^{31}-1)\) 求 \(\begin{aligned} ans_1=\sum_{i=1}^n\varph ...

  6. luoguP4213 【模板】杜教筛(Sum)杜教筛

    链接 luogu 思路 为了做hdu来学杜教筛. 杜教筛模板题. 卡常数,我加了register居然跑到不到800ms. 太深了. 代码 // luogu-judger-enable-o2 #incl ...

  7. 【模板】杜教筛(Sum)

    传送门 Description 给定一个正整数\(N(N\le2^{31}-1)\) 求 \[ans1=\sum_{i=1}^n \varphi(i)\] \[ans_2=\sum_{i=1}^n \ ...

  8. P4213【模板】杜教筛(Sum)

    思路:杜教筛 提交:\(2\)次 错因:\(\varphi(i)\)的前缀和用\(int\)存的 题解: 对于一类筛积性函数前缀和的问题,杜教筛可以以低于线性的时间复杂度来解决问题. 先要构造\(h= ...

  9. LG4213 【【模板】杜教筛(Sum)】

    sum\(\mu\)求法 设 \[S(n)=\sum_{i=1}^n \mu(i)\] 回顾公式 \[\sum_{d|n}\mu(d)=[n=1]\] 对\(n\)求和 \[\sum_{i=1}^n\ ...

  10. P4213 【模板】杜教筛(Sum)(杜教筛)

    根据狄利克雷卷积的性质,可以在低于线性时间复杂度的情况下,求积性函数前缀和 公式 \[ 求\sum_{i=1}^{n}\mu(i) \] 因为\(\mu*I=\epsilon\) 所以设\(h=\mu ...

随机推荐

  1. alertifyjs

    <%@ page contentType="text/html; charset=UTF-8"%> <!DOCTYPE html PUBLIC "-// ...

  2. 插入排序Insertion Sort

    插入排序:将一个数据插入到一个已经排好序的有序数据序列中,从而得到一个新的.个数+1的有序数列:插入排序适用于少量数据排序,时间复杂度为O(n^2). 实现思路:1.对于一个无序数组,选取第一个元素, ...

  3. java thread 线程锁同步,锁,通信

    12.线程同步 当多个线程访问同一个数据时,非常容易出现线程安全问题.这时候就需要用线程同步 Case:银行取钱问题,有以下步骤: A.用户输入账户.密码,系统判断是否登录成功 B.用户输入取款金额 ...

  4. shell 颜色控制系列

    shell脚本里,经常用的颜色控制,如下 格式:echo -e "\033[字背景颜色:文字颜色m字符串\033[0m" eg:echo -e "\033[41;36m ...

  5. Centos下Sphinx的下载与编译安装

    官方下载地址   http://sphinxsearch.com/downloads/release/ 百度云下载地址  https://pan.baidu.com/s/1gfmPbd5 wget  ...

  6. 我的Java设计模式-单例模式

    就算不懂设计模式的兄弟姐妹们,想必也听说过单例模式,并且在项目中也会用上.但是,真正理解和熟悉单例模式的人有几个呢?接下来我们一起来学习设计模式中最简单的模式之一--单例模式 一.为什么叫单例模式? ...

  7. java I/O框架 (三)基本流

    概述 基本流有字节输入输出流(InputStream,OutputStream),和字符输入输出流(Reader,Writer),它们都是抽象类,作为Java IO API中其他所有流的父类存在. 我 ...

  8. Python模拟登录成功与失败处理方式(不涉及前端)

    任务说明: (1) 用户输入用户名,如不存在此用户不能登录: (2) 用户在输入密码时,如果连续输入三次错误,则该用户被锁定一段时间; (3) 用户被锁定一段时间后,可再次进行尝试登录: 程序使用库: ...

  9. ROM型启动方式概述

    ROM 型启动方式概述 所有的VxWorks 内核映像类型中,只有VxWorks 类型使用的bootrom 引导程序进行启动,此时VxWorks 内核映像放置在主机端,由目标板bootrom 完成Vx ...

  10. 使用ifstream和getline读取文件内容[c++]

    转载:http://www.cnblogs.com/JCSU/articles/1190685.html 假设有一个叫 data.txt 的文件, 它包含以下内容: Fry: One Jillion ...