P4213 杜教筛

本文介绍了杜教筛的概念,它用于解决当需要计算大量积性函数前缀和时的问题。以求莫比乌斯函数u和欧拉函数phi的前缀和为例,阐述了如何运用杜教筛公式进行计算。在实际编程中,通过线性筛预先计算并存储前1e7个数的phi和u的前缀和,超过这个范围则使用记忆化搜索和哈希映射,从而避免超时。
摘要由CSDN通过智能技术生成

首先引入这三个函数:
在这里插入图片描述
在引入三个常见的迪利克雷卷积:
在这里插入图片描述
下面进入正题,所谓杜教筛,其实就是一个求积性函数前缀和的定理,如果要求的前缀和数量太大,比如前1e9个数的和,就没法通过累加解决,所以就有了我们的杜教筛。杜教筛主要的核心就是一个公式:
在这里插入图片描述
这个题的题意是要求莫比乌斯函数u和欧拉函数phi的前缀和,n的大小在2^31以内。
如何利用杜教筛解决这个问题呢?
我们需要做的就是寻找合适的函数帮助我们凑出杜教筛的核心公式,S(n)毋庸置疑就是sigma_u和sigma_phi了,我们只需要找合适的函数来代替g和h即可,函数我也给出了,就是我前面给出的三个函数,那么这个题我采用的是b站大佬视频中采用的:

在这里插入图片描述

我在做这个题的时候遇到tle的问题,因为递归迭代的次数太多了,所以就听了实验室xyx巨佬的方法,把前1e7个phi和u用线性筛筛出来,求出前缀和保存在数组里,这样返回1e7以内的数的时候就可以直接返回,大于1e7的就记忆化搜索用哈希map保存,妙哉。
下面附上我的代码:

//#pragma GCC optimize(3,"Ofast","inline")
#include<unordered_map>
#include<unordered_set>
#include<cstdio>
#include<iostream>
#include<cmath>
#include<functional>
#include<cstring>
#include<string>
#include<cstdlib>
#include<queue>
#include<map>
#include<algorithm>
#include<set>
#include<stack>
#include<vector>
#include<sstream>
#include<list>
using namespace std;
typedef long long ll;
const int INF=0x3f3f3f3f;
const int maxn= 2e7+10;
const ll mod=6662333;
const int N=210000;
unordered_map<int,ll>m1;
unordered_map<int,ll>m2;
int prime[maxn],isprime[maxn];
ll phi[maxn];
int num;
ll mob[maxn];
void getphi(int n)
{
    memset(prime,0,sizeof(prime));
    memset(isprime,1,sizeof(isprime));
    memset(mob,0,sizeof(mob));
    phi[1]=1;
    mob[1]=1;
    for(int i=2;i<=n;i++)
    {
        if(isprime[i])
        {
            phi[i]=i-1;
            mob[i]=-1;
            prime[num++]=i;
        }
        for(int j=0;j<num&&i*prime[j]<=n;j++)
        {
            isprime[i*prime[j]]=0;
            if(i%prime[j]==0){
                phi[i*prime[j]]=phi[i]*prime[j];
                mob[i*prime[j]]=0;
                break;
            }
            else
            {
                mob[i*prime[j]]=-mob[i];
                phi[i*prime[j]]=phi[i]*phi[prime[j]];
            }
        }
    }
}
ll s1(ll x)
{
    if(x==1)return 1;
    if(x<=10000000)return mob[x];
    if(m1[x])return m1[x];
    ll sum=0;
    ll l,r;
    for(l=2;l<=x;l=r+1)
    {
        r=x/(x/l);
        sum+=(r-l+1)*s1(x/l);
    }
    return m1[x]=1-sum;
}
ll s2(ll x)
{
    if(x==1)return 1;
    if(x<=10000000)return phi[x];
    if(m2[x])return m2[x];
    ll sum=0;
    ll l,r;
    for(l=2;l<=x;l=r+1)
    {
        r=x/(x/l);
        sum+=(r-l+1)*s2(x/l);
    }
    return m2[x]=(x+1)*x/2-sum;
}
int main()
{
    int t;
    getphi(10000000);
    cin>>t;
    ll x;
    for(int i=2;i<=10000000;i++)
    {
        mob[i]+=mob[i-1];
        phi[i]+=phi[i-1];
    }
    while(t--)
    {
        cin>>x;
        cout<<s2(x)<<" "<<s1(x)<<endl;
    }
    return 0;
}

本人在做的时候,先是筛了1e5,只过了6个数据,因为有种打表的感觉,莫名觉得很爽,所以就增加到1e6,过了9个,还不够,我就露出了阴间的笑容,上1e7,ac!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问题的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面中可以对界面中显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面中查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值