【LOJ#6682】梦中的数论(min_25筛)

题面

LOJ

题解

注意题意是\(j|i\)并且\((j+k)|i\),

不难发现\(j\)和\((j+k)\)可以任意取\(i\)的任意因数,且\(j\lt j+k\),所以答案就是:

\[Ans=\sum_{i=1}^n {\sigma(i)\choose 2}
\]

所以要做的就是筛\(\sigma^2(i)\)和\(\sigma(i)\)的前缀和。

\(\sigma(i)\)这个东西就是\(\displaystyle \sum_{i=1}^n \lfloor\frac{n}{i} \rfloor\),可以用数论分块在\(O(\sqrt n)\)的时间内求解。

然后这两个东西都是积性函数,所以算\(\sigma^2\)可以直接\(min\_25\)筛,本质上是筛质数个数。

然后讨论一下边界:\(f(1)=1,f(p^k)=(k+1)^2\)。

转移啥的就很显然了。

#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
#define ll long long
#define MAX 200200
#define MOD 998244353
ll n;int ans;
ll id1[MAX],id2[MAX],w[MAX],m,f[MAX];
int ID(ll x){return x<MAX?id1[x]:id2[n/x];}
bool zs[MAX];
int pri[MAX],tot;
void Sieve(int n)
{
for(int i=2;i<=n;++i)
{
if(!zs[i])pri[++tot]=i;
for(int j=1;j<=tot&&i*pri[j]<=n;++j)
{
zs[i*pri[j]]=true;
if(i%pri[j]==0)break;
}
}
}
int Sqr(int x){return 1ll*x*x%MOD;}
int S(ll x,int y)
{
if(x<=1||pri[y]>x)return 0;
int k=ID(x),ret=4ll*(f[k]-y+1)%MOD;
for(int i=y;i<=tot&&1ll*pri[i]*pri[i]<=x;++i)
{
ll t1=pri[i],t2=1ll*pri[i]*pri[i];
for(int e=1;t2<=x;++e,t1=t2,t2*=pri[i])
ret=(ret+1ll*Sqr(e+1)*S(x/t1,i+1)+Sqr(e+2))%MOD;
}
return ret;
}
int main()
{
cin>>n;Sieve(sqrt(n));
for(ll i=1,j;i<=n;i=j+1)
{
j=n/(n/i);ans=(ans+MOD-1ll*(n/i)%MOD*((j-i+1)%MOD)%MOD)%MOD;
w[++m]=n/i;f[m]=(w[m]-1+MOD)%MOD;
if(w[m]<MAX)id1[w[m]]=m;
else id2[j]=m;
}
for(int j=1;j<=tot;++j)
for(int i=1;i<=m&&1ll*pri[j]*pri[j]<=w[i];++i)
{
int k=ID(w[i]/pri[j]);
f[i]=(f[i]+MOD-(f[k]+MOD-(j-1)%MOD)%MOD)%MOD;
}
ans=1ll*(ans+S(n,1)+1)*(MOD+1)/2%MOD;
printf("%d\n",ans);
return 0;
}

【LOJ#6682】梦中的数论(min_25筛)的更多相关文章

  1. 模板 - 数学 - 数论 - Min_25筛

    终于知道发明者的正确的名字了,是Min_25,这个筛法速度为亚线性的\(O(\frac{n^{\frac{3}{4}}}{\log x})\),用于求解具有下面性质的积性函数的前缀和: 在 \(p\) ...

  2. 51Nod1222 最小公倍数计数 数论 Min_25 筛

    原文链接https://www.cnblogs.com/zhouzhendong/p/51Nod1222.html 题意 给定 $a,b$, 求 $$\sum_{n=a}^b \sum_{i=1}^n ...

  3. loj 572 Misaka Network 与求和 —— min_25筛

    题目:https://loj.ac/problem/572 推式子:https://www.cnblogs.com/cjoieryl/p/10150718.html 又学习了一下杜教筛hh: 原来 u ...

  4. loj#6053. 简单的函数(Min_25筛)

    传送门 题解 \(Min\_25\)筛有毒啊--肝了一个下午才看懂是个什么东西-- \(zsy\)巨巨强无敌-- //minamoto #include<bits/stdc++.h> #d ...

  5. LOJ6682 梦中的数论

    题目 不难发现我们要求的东西是\(\sum_{i=1}^n\binom{\sigma(i)}{2}=\sum_{i=1}^n\frac{\sigma(i)(\sigma(i)-1)}{2}=\frac ...

  6. LOJ.6235.区间素数个数(Min_25筛)

    题目链接 \(Description\) 给定\(n\),求\(1\sim n\)中的素数个数. \(2\leq n\leq10^{11}\). \(Solution\) Min_25筛.只需要求出\ ...

  7. 【LOJ#572】Misaka Network 与求和(莫比乌斯反演,杜教筛,min_25筛)

    [LOJ#572]Misaka Network 与求和(莫比乌斯反演,杜教筛,min_25筛) 题面 LOJ \[ans=\sum_{i=1}^n\sum_{j=1}^n f(gcd(i,j))^k\ ...

  8. LOJ 6053 简单的函数——min_25筛

    题目:https://loj.ac/problem/6053 min_25筛:https://www.cnblogs.com/cjyyb/p/9185093.html 这里把计算 s( n , j ) ...

  9. 数论(8):min_25 筛(扩展埃氏筛)

    min_25 筛介绍 我们考虑这样一个问题. \[ans=\sum_{i = 1}^nf(i)\\ \] 其中 \(1 \le n \le 10^{10}\) 其中 \(f(i)\) 是一个奇怪的函数 ...

随机推荐

  1. 13. Go 语言网络爬虫

    Go 语言网络爬虫 本章将完整地展示一个应用程序的设计.编写和简单试用的全过程,从而把前面讲到的所有 Go 知识贯穿起来.在这个过程中,加深对这些知识的记忆和理解,以及再次说明怎样把它们用到实处.由本 ...

  2. Codechef RIN 「Codechef14DEC」Course Selection 最小割离散变量模型

    问题描述 提供中文版本好评,一直以为 Rin 是题目名字... pdf submit 题解 参考了 东营市胜利第一中学姜志豪 的<网络流的一些建模方法>(2016年信息学奥林匹克中国国家队 ...

  3. Java内存分析工具MAT

    MAT是一个强大的内存分析工具,可以快捷.有效地帮助我们找到内存泄露,减少内存消耗分析工具.内存中堆的使用情况是应用性能监测的重点,而对于堆的快照,可以dump出来进一步分析,总的来说,一般我们对于堆 ...

  4. SpringCloud gateway (史上最全)

    疯狂创客圈 Java 分布式聊天室[ 亿级流量]实战系列之 -25[ 博客园 总入口 ] 前言 ### 前言 疯狂创客圈(笔者尼恩创建的高并发研习社群)Springcloud 高并发系列文章,将为大家 ...

  5. Java题库——Chapter5 方法

    1)Suppose your method does not return any value, which of the following keywords can be used as a re ...

  6. Asp .Net Core Excel导入和导出

    ASP .Net Core使用EPPlus实现Api导入导出,这里使用是EPPlus 4.5.2.1版本,.Net Core 2.2.在linux上运行的时候需要安装libgdiplus . 下面我们 ...

  7. 用户APC的执行过程

    Windows内核分析索引目录:https://www.cnblogs.com/onetrainee/p/11675224.html 用户APC的执行过程 一.一个启发式问题 有一个问题,线程什么时候 ...

  8. git push 时用户的配置

    Pycharm临时配置git提交的账户:git 修改当前的project的用户名的命令为:git config user.name 你的目标用户名**;git 修改当前的project提交邮箱的命令为 ...

  9. JPA连接Mysql数据库时提示:Table 'jpa.sequence' dosen't exisit

    场景 在使用JPA连接Mysql数据库进行数据持久化时提示: Table 'jpa.sequence' dosen't exist 注: 博客主页: https://blog.csdn.net/bad ...

  10. 记录一次netcore3.0 code first使用迁移命令报错问题

    环境描述:macOS .vscode .netcore3.0 迁移工具:Microsoft.EntityFrameworkCore.Tools 遇到的问题: Could not execute bec ...