20191212模拟赛 问题B
题目:
分析:
上来看到k=2,。。。
SB杜教筛phi
有点感冒,这把养生一点。。。
于是写了55分走人了。。
下来一看挺简单的啊2333
不考虑gcd时,构造数列的方案为C(N+K-1,K)
考虑gcd时,就要套mu了
ans=sigma(i=1...n)mu[i]*F(n/i)
其中f(x)=C(x+K-1,K)
然后有一个公式。。。
summu[n]=1-sigma(d=2...n)summu[n/d]
这样就可以n^(2/3)求summu了
对于F,由于K很小,可以暴力算。。。
但是这样极限数据会很卡诶。。。
考虑F分段处理
当x+K-1小于1e6时,可以预处理组合数
又由于x+K-1大于1e6的情况很少。。。
所以是可以过的2333。。。。
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<queue>
#include<map> #define maxn 1000005
#define INF 0x3f3f3f3f
#define MOD 1000000007 using namespace std; inline int getint()
{
int num=,flag=;char c;
while((c=getchar())<''||c>'')if(c=='-')flag=-;
while(c>=''&&c<='')num=num*+c-,c=getchar();
return num*flag;
} int n,K;
int N=;
int pri[maxn],cnt,np[maxn];
int mu[maxn];
long long fac[maxn],inv[maxn];
long long ans;
map<int,long long>M; inline void init()
{
mu[]=;
for(int i=;i<=N;i++)
{
if(!np[i])pri[++cnt]=i,mu[i]=-;
for(int j=;j<=cnt&&i*pri[j]<=N;j++)
{
np[i*pri[j]]=;
if(i%pri[j]==)break;
mu[i*pri[j]]=-mu[i];
}
}
for(int i=;i<=N;i++)mu[i]+=mu[i-];
for(int i=;i<=N;i++)(mu[i]+=MOD)%=MOD;
fac[]=fac[]=inv[]=inv[]=;
for(int i=;i<=N;i++)fac[i]=fac[i-]*i%MOD;
for(int i=;i<=N;i++)inv[i]=inv[MOD%i]*(MOD-MOD/i)%MOD;
for(int i=;i<=N;i++)inv[i]=inv[i]*inv[i-]%MOD;
} inline long long solve(int x)
{
if(x<=N)return mu[x];
if(M.count(x))return M[x];
long long num=;
for(int i=,j;i<=x;i=j+)
{
j=x/(x/i);
(num-=(j-i+)*solve(x/i)%MOD)%=MOD;
}
return M[x]=(num+MOD)%MOD;
} inline long long C(int p,int q)
{return fac[p]*inv[q]%MOD*inv[p-q]%MOD;} inline long long cal(int x)
{
if(x+K-<=N)return C(x+K-,K);
long long tmp=;
for(int i=;i<=K;i++)tmp=tmp*((x+K-)-i+)%MOD;
return tmp*inv[K]%MOD;
} int main()
{
int T=getint();
init();
while(T--)
{
M.clear();
n=getint(),K=getint();
ans=;
for(int i=,j;i<=n;i=j+)
{
j=n/(n/i);
(ans+=(solve(j)-solve(i-)+MOD)*cal(n/i)%MOD)%=MOD;
}
printf("%lld\n",ans);
}
}
20191212模拟赛 问题B的更多相关文章
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- NOI模拟赛 Day1
[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...
- NOIP第7场模拟赛题解
NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 小奇模拟赛9.13 by hzwer
2015年9月13日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...
- PKUSC 模拟赛 day1 下午总结
下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...
- [GRYZ]寒假模拟赛
写在前面 这是首次广饶一中的OIERS自编自导,自出自做(zuo)的模拟赛. 鉴于水平气压比较低,机(wei)智(suo)的WMY/XYD/HYXZC就上网FQ下海找了不少水(fei)题,经过他们优( ...
- BZOJ2741: 【FOTILE模拟赛】L
2741: [FOTILE模拟赛]L Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 1170 Solved: 303[Submit][Status] ...
随机推荐
- git 上传当前分支
因为我现在的分支是的名很长,每次需要上次当前分支需要写很多代码,是不是有很简单方法上传当前分支. 如果要上传一个分支到仓库 origin 那么就需要使用下面的命令 git push origin 分支 ...
- javascript拷贝
function copy(obj){ //浅拷贝 var result = {}; for(var attr in obj){ result[attr] = obj[attr]; } return ...
- Android APP前后台状态切换
getActivity().getApplication().registerActivityLifecycleCallbacks(new Application.ActivityLifecycleC ...
- Keras cnn 手写数字识别示例
#基于mnist数据集的手写数字识别 #构造了cnn网络拟合识别函数,前两层为卷积层,第三层为池化层,第四层为Flatten层,最后两层为全连接层 #基于Keras 2.1.1 Tensorflow ...
- Volatile是用于解决什么问题,谈谈实现原理
一.volatile的作用 通常情况下我们可以通过Synchronized关键字来解决这些个问题,不过如果对Synchronized原理有了解的话,应该知道Synchronized是一个比较重量级的操 ...
- spring boot(二)热部署
1.打开idea的设置界面 File | Settings > Build, Execution, Deployment > Compiler 2.勾选Buildproject antom ...
- Java8 LocalDate计算两个日期的间隔天数
Java8新增了java.time包,提供了很多新封装好的类,使我们可以摆脱原先使用java.util.Time以及java.util.Calendar带来的复杂. 其中LocalDate正是本文中使 ...
- $bzoj4722$ 由乃 搜索
正解:搜索 解题报告: 传送门$QwQ$ 首先发现长度为$len$的子集的值域为$[0,v\cdot len+len]$,数量为$2^{len}$.所以当$2^{len}\geq v\cdot len ...
- 初识python——知其名而去其意
---背景 b2b,房地产,人工智能是今年最火的词汇,那么配套的软件技术究竟是怎样的呢,通过百度,园子里的信息分析,自我感觉需要用python来进行数据采集. ---环境 在百度,qq群的大神指导下, ...
- Java工作流系统-父子流程的配置讲解
父子流程 关键字: 驰骋工作流程快速开发平台 工作流程管理系统 工作流引擎 asp.net工作流引擎 java工作流引擎. 开发者表单 拖拽式表单 工作流系统 适配数据库: oralce,mysql ...