51nod 1965 奇怪的式子 —— min_25筛
题目:http://www.51nod.com/Challenge/Problem.html#!#problemId=1965
推式子就同这里:https://www.cnblogs.com/yoyoball/p/9196092.html
一开始想设 \( g(n,j) = \sum\limits_{i=1}^{n} [ min(i) >= p_{j} ] f(i) \),其中 \( f(i) = d(i) \mu(i) \) 或 \( f(i) = mu(i) \),\( d(i) \) 是质因子个数;
结果发现枚举最小质因子还好(但是太慢了会TLE啊!),改成循环来筛的话很不好赋初值啊!而且筛的过程也感觉怪怪的,弄了半天还是不对...
于是就也把 \( g(n,j) \) 设成 \( g(n,j) = \sum\limits_{i=1}^{n} [ i \in prime || min(i) >= p_{j} ] f(i) \) 了,果然就对了...
这里因为 \( d(i) \mu(i) \) 不是积性函数,所以要考虑 \( d(i) \) 少加的部分,再补回来即可(就是加一个 \( \sum \mu(i) \) );
long double 快速乘;
注意多组数据!虽然也不用清空什么数组,但因为我在过程中用到了 \( s[m+1] \) 和 \( sum[m+1] \),所以要把这两个清零。
代码如下:
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
typedef long long ll;
typedef long double ld;
int const xn=1e6+;
ll const mod=1e12+,md=mod-;
int m,pri[xn],cnt,sqr;
ll n,w[xn],h[xn],s[xn],ps[xn],sum[xn],f[xn],g[xn];
bool vis[xn];
ll upt(ll x){while(x>=mod)x-=mod; while(x<)x+=mod; return x;}
ll upt2(ll x){while(x>=md)x-=md; while(x<)x+=md; return x;}
/*
ll mul(ll a,ll b){ll ret=0; for(;b;b>>=1,a=upt(a+a))if(b&1)ret=upt(ret+a); return ret;}
ll mul2(ll a,ll b){ll ret=0; for(;b;b>>=1,a=upt2(a+a))if(b&1)ret=upt2(ret+a); return ret;}
*/
ll mul(ll a,ll b){ll r=(ld)a*b/mod; return a*b-r*mod;}
ll mul2(ll a,ll b){ll r=(ld)a*b/md; return a*b-r*md;}
ll pw(ll a,ll b){ll ret=; for(;b;b>>=,a=mul(a,a))if(b&)ret=mul(ret,a); return ret;}
ll pw2(ll a,ll b){ll ret=; for(;b;b>>=,a=mul2(a,a))if(b&)ret=mul2(ret,a); return ret;}
void init(int mx)
{
for(int i=;i<=mx;i++)
{
if(!vis[i])pri[++cnt]=i,ps[cnt]=upt2(ps[cnt-]+i);
for(int j=;j<=cnt&&(ll)i*pri[j]<=mx;j++)
{
vis[i*pri[j]]=;
if(i%pri[j]==)break;
}
}
}
int Id(ll x)
{
if(x>sqr)return n/x;
return m-x+;
}
ll F(ll x,int y)
{
if(pri[y]>x)return ;
ll ret=upt2(-h[Id(x)]+y-);
for(int i=y;i<=cnt&&(ll)pri[i]*pri[i]<=x;i++)
ret=upt2(ret-F(n/pri[i],i+));
return ret;
}
ll G(ll x,int y)
{
if(pri[y]>x)return ;
ll ret=upt2(-h[Id(x)]+y-);
for(int i=y;i<=cnt&&(ll)pri[i]*pri[i]<=x;i++)
ret=upt2(ret-G(n/pri[i],i+)-F(n/pri[i],i+));
return ret;
}
int main()
{
int T; scanf("%d",&T); init(1e6);
while(T--)
{
scanf("%lld",&n); sqr=sqrt(n); m=;//
int up; for(up=cnt;(ll)pri[up]*pri[up]>n;up--);
for(ll i=,j;i<=n;i=j+)
{
w[++m]=n/i; j=n/w[m];
h[m]=w[m]-;
if(w[m]&)sum[m]=mul2((w[m]+)/,w[m]);
else sum[m]=mul2(w[m]/,(w[m]+));
s[m]=upt2(sum[m]-);
}
s[m+]=; sum[m+]=;//!!!
for(int j=;j<=up;j++)
for(int i=;i<=m&&(ll)pri[j]*pri[j]<=w[i];i++)
{
int k=Id(w[i]/pri[j]);
h[i]=upt2(h[i]-h[k]+(j-));
s[i]=upt2(s[i]-mul2(s[k],pri[j]));
s[i]=upt2(s[i]+mul2(ps[j-],pri[j]));//pri[j]
}
//for(int i=1;i<=m;i++)printf("sum[%d]=%lld ",i,sum[i]); puts("");
//for(int i=1;i<=m;i++)printf("s[%d]=%lld ",i,s[i]); puts("");
ll res=;
for(ll i=,j;i<=n;i=j+)
{
j=n/(n/i);
res=upt2(res+mul2(sum[Id(n/i)],upt2(s[Id(j)]-s[Id(i-)])));//s[m+1]!
}
for(int i=;i<=up;i++)
res=upt2(res-mul2(pri[i],sum[Id(n/pri[i])]));
ll ans=pw(,res);
for(int i=;i<=up;i++)
for(ll k=,p0=pri[i];p0<=n;p0*=pri[i],k++)
{
ll r=upt2(mul2(p0,sum[Id(n/p0)])-mul2(p0*pri[i],sum[Id(n/p0/pri[i])]));//sum[m+1]!
ans=mul(ans,pw(k+,r));
}
//ans=mul(ans,pw(2,G(n,1)));
/*
for(int i=1;i<=m;i++)
{
//if(w[i]>sqr)f[i]=g[i]=upt2(-(h[Id(n)]-h[i]+1));
//else f[i]=g[i]=upt2(-(h[Id(n)]-up));
if(h[i]<=up)f[i]=g[i]=upt2(-(h[Id(n)]-up));
else f[i]=g[i]=upt2(-(h[Id(n)]-h[i]+1));
}
for(int j=up;j;j--)
for(int i=1;i<=m&&(ll)pri[j]*pri[j]<=w[i];i++)
{
int k=Id(w[i]/pri[j]);
f[i]=upt2(f[i]-f[k]-1);//mu[pj]
g[i]=upt2(g[i]-g[k]-1-f[k]-1);
}
*/
for(int i=;i<=m;i++)f[i]=g[i]=upt2(-h[i]);
for(int j=up;j;j--)
for(int i=;i<=m&&(ll)pri[j]*pri[j]<=w[i];i++)
{
int k=Id(w[i]/pri[j]);
f[i]=upt2(f[i]-f[k]-j);
g[i]=upt2(g[i]-g[k]-j-f[k]-j);
}
ans=mul(ans,pw(,g[Id(n)]));
printf("%lld\n",ans);
}
return ;
}
51nod 1965 奇怪的式子 —— min_25筛的更多相关文章
- 51nod 1965 奇怪的式子——min_25筛
题目:http://www.51nod.com/Challenge/Problem.html#!#problemId=1965 考虑 \( \prod_{i=1}^{n}\sigma_0^i \) \ ...
- 【51NOD1965】奇怪的式子 min_25筛
题目描述 给你\(n\),求 \[ \prod_{i=1}^n{\sigma_0(i)}^{i+\mu(i)} \] 对\({10}^{12}+39\)取模. \(\sigma_0(i)\)表示约数个 ...
- 【51NOD1847】奇怪的数学题 min_25筛
题目描述 记\(sgcd(i,j)\)为\(i,j\)的次大公约数. 给你\(n\),求 \[ \sum_{i=1}^n\sum_{j=1}^n{sgcd(i,j)}^k \] 对\(2^{32}\) ...
- 51nod1847 奇怪的数学题 (Min_25筛+第二类斯特林数)
link \(\sum_{i=1}^n\sum_{j=1}^n\mathrm{sgcd}(i,j)^k=\sum_{p=1}^ns(p)^k\sum_{i=1}^n\sum_{j=1}^n[\gcd( ...
- 【51NOD 1847】奇怪的数学题(莫比乌斯反演,杜教筛,min_25筛,第二类斯特林数)
[51NOD 1847]奇怪的数学题(莫比乌斯反演,杜教筛,min_25筛,第二类斯特林数) 题面 51NOD \[\sum_{i=1}^n\sum_{j=1}^nsgcd(i,j)^k\] 其中\( ...
- 51nod1965. 奇怪的式子(min_25筛)
题目链接 http://www.51nod.com/Challenge/Problem.html#!#problemId=1965 题解 需要求的式子显然是个二合一形式,我们将其拆开,分别计算 \(\ ...
- 【51nod1965】奇怪的式子
Portal --> 51nod1965 Solution 怎么说呢..这题..做的有点痛苦.. 首先看这个式子长得..比较奇怪,指数里面那个加号有点烦人,而且这个函数不是一个积性函数也有点烦人 ...
- 【UOJ448】【集训队作业2018】人类的本质 min_25筛
题目大意 给你 \(n,m\),求 \[ \sum_{i=1}^n\sum_{x_1,x_2,\ldots,x_m=1}^i\operatorname{lcm}(\gcd(i,x_1),\gcd(i, ...
- Min_25 筛 学习笔记
原文链接https://www.cnblogs.com/zhouzhendong/p/Min-25.html 前置技能 埃氏筛法 整除分块(这里有提到) 本文概要 1. 问题模型 2. Min_25 ...
随机推荐
- Spring中Bean管理的常用注解
在Spring中,主要用于管理bean的注解分为四大类:1.用于创建对象.2.用于给对象的属性注入值.3.用于改变作用的范围.4.用于定义生命周期.这几个在开发中经常接触到,也可以说每天都会遇见.其中 ...
- java.lang.IllegalStateException: ContainerBase.addChild: start: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[]]
1.问题描述: 对于创建的springboot项目,通过启动类启动,访问没问题,但打成war部署到tomcat上启动报错,如下: 严重: ContainerBase.addChild: start: ...
- kafka和canal设置为开机启动
1.切换到初始化目录 cd /etc/init.d/ 2.新建一个文件 如 touch autoupdate 3.vim autoupdate #!/bin/bash export JAVA_HOME ...
- CentOS上使用sendmail发送邮件
设置方法 set from=fromUser@domain.com smtp=smtp.domain.com set smtp-auth-user=username smtp-auth-passwor ...
- SQL编码规范
1 目的 为了保证所每个项目组编写出的程序都符合相同的规范,便于理解和维护,便于检查.减少出错概率,有助于成员间交流,保证一致性.统一性而建立的SQL程序编码规范. 2 范 ...
- 判断浏览器是否支持某一个CSS3属性
判断浏览器是否支持某一个CSS3属性 function supportCss3(style) { var prefix = ['webkit', 'Moz', 'ms', 'o'], i, humpS ...
- websocket之django简单使用
WebSocket protocol: WebSocket protocol 是HTML5一种新的协议.它是实现了浏览器与服务器全双工通信(full-duplex).HTML5定义了WebSocket ...
- 分享知识-快乐自己:能使 Oracle 索引失效的六大限制条件
Oracle 索引的目标是避免全表扫描,提高查询效率,但有些时候却适得其反. 例如一张表中有上百万条数据,对某个字段加了索引,但是查询时性能并没有什么提高,这可能是 oracle 索引失效造成的.or ...
- java之字符串中查找字串的常见方法
1.int indexOf(String str) :返回第一次出现的指定子字符串在此字符串中的索引. int indexOf(String str, int startIndex):从指定 ...
- tomcat学习篇
要求: 为Apache HTTP Server服务器添加JSP网页支持. 能够访问Tomcat容器的Web管理界面,以便管理各种JSP.Servelet应用. u 知识提示 在各种企业级网站应用系统中 ...