bzoj5019: [Snoi2017]遗失的答案
Description
Input
Output
如果L%G非零则无解,将L的每个质因子看作一维,只有每维都取到最小(L中对应质数的次数)和最大幂次(G中对应质数的次数),才能得到对应的G和L,状压表示每一维的质因数次数是否取到最小/大值,可以选的数一定每维幂次在最小值和最大值之间,这样的数很少,在数据范围内不超过800个,分治dp得出某个数不选的方案数,用总方案数减去即得到某个数必选的方案数。时间复杂度为O((L的约数个数)*log(L的约数个数)*4^(L的不同质因子个数))
#include<bits/stdc++.h>
typedef int mat[][];
const int P=1e9+;
int _(){
int x=,c=getchar();
while(c<)c=getchar();
while(c>)x=x*+c-,c=getchar();
return x;
}
int n,g,l,qp,mx,fs[],tg[],tl[],fp=,ans[];
inline void inc(int&a,int b){a+=b-P,a+=a>>&P;}
struct dat{
int v,s1,s2;
bool operator<(const dat&w)const{return v<w.v;}
void trans(mat a){
for(int i=mx-;i>=;--i){
int*m1=a[i],*m2=a[i|s1];
for(int j=mx-;j>=;--j)inc(m2[j|s2],m1[j]);
}
}
}vs[];
int vp=;
void f1(int x){
for(int i=;i*i<=x;++i)if(x%i==){
do x/=i;while(x%i==);
fs[fp++]=i;
}
if(x>)fs[fp++]=x;
}
void f2(int x,int*t){
for(int i=;i<fp;++i)for(;x%fs[i]==;x/=fs[i],++t[i]);
}
void dfs(int w,int v,int s1,int s2){
if(w==fp){
if(v<=n)vs[++vp]=(dat){v,s1,s2};
return;
}
for(int i=;i<=tl[w];++i,v*=fs[w]){
if(i>=tg[w])dfs(w+,v,s1|(i==tg[w])<<w,s2|(i==tl[w])<<w);
}
}
mat F[];
int Fp=,all;
void cpy(){
for(int i=;i<mx;++i)memcpy(F[Fp+][i],F[Fp][i],sizeof(int)*mx);
++Fp;
}
void solve(int L,int R){
if(L==R){
if(R==){
cpy();
vs[].trans(F[Fp]);
all=F[Fp][mx-][mx-];
--Fp;
}
ans[L]=((all-F[Fp][mx-][mx-])%P+P)%P;
return;
}
int M=L+R>>;
cpy();
for(int i=M+;i<=R;++i)vs[i].trans(F[Fp]);
solve(L,M);
--Fp;
cpy();
for(int i=L;i<=M;++i)vs[i].trans(F[Fp]);
solve(M+,R);
--Fp;
}
void nos(){
while(qp--)puts("");
exit();
}
int main(){
n=_(),g=_(),l=_(),qp=_();
f1(g),f1(l);
std::sort(fs,fs+fp);
fp=std::unique(fs,fs+fp)-fs;
f2(g,tg),f2(l,tl);
if(n<g)nos();
for(int i=;i<fp;++i)if(tg[i]>tl[i])nos();
dfs(,,,);
std::sort(vs+,vs+vp+);
mx=<<fp;
F[][][]=;
solve(,vp);
while(qp--){
int x=_(),w=std::lower_bound(vs+,vs+vp+,(dat){x})-vs;
if(w<=vp&&vs[w].v==x)printf("%d\n",ans[w]);
else puts("");
}
return ;
}
bzoj5019: [Snoi2017]遗失的答案的更多相关文章
- BZOJ5019 SNOI2017遗失的答案(容斥原理)
显然存在方案的数一定是L的因数,考虑对其因子预处理答案,O(1)回答. 考虑每个质因子,设其在g中有x个,l中有y个,则要求所有选中的数该质因子个数都在[x,y]中,且存在数的质因子个数为x.y.对于 ...
- BZOJ5019[Snoi2017]遗失的答案——FWT+状压DP
题目描述 小皮球在计算出答案之后,买了一堆皮肤,他心里很开心,但是一不小心,就忘记自己买了哪些皮肤了.==|||万 幸的是,他还记得他把所有皮肤按照1-N来编号,他买来的那些皮肤的编号(他至少买了一款 ...
- 【BZOJ5019】[SNOI2017]遗失的答案(FWT,动态规划)
[BZOJ5019][SNOI2017]遗失的答案(FWT,动态规划) 题面 BZOJ 题解 发现\(10^8\)最多分解为不超过\(8\)个本质不同质数的乘积. 而\(gcd\)和\(lcm\)分别 ...
- bzoj 5019: [Snoi2017]遗失的答案【dp+FWT】
满足GL的组合一定包含GL每个质因数最大次幂个最小次幂,并且能做限制这些数不会超过600个 然后质因数最多8个,所以可以状压f[s1][s2]为选s1集合满足最大限制选s2集合满足最小限制 dfs一下 ...
- bzoj 5019 [Snoi2017]遗失的答案
题面 https://www.lydsy.com/JudgeOnline/problem.php?id=5019 题解 如果L不是G的倍数 答案为0 下面考虑G|L的情况 将G,L质因数分解 设$L= ...
- LOJ2257 SNOI2017 遗失的答案 容斥、高维前缀和
传送门 数字最小公倍数为\(L\)的充分条件是所有数都是\(L\)的约数,而\(10^8\)内最多约数的数的约数也只有\(768\)个.所以我们先暴力找到所有满足是\(L\)的约数.\(G\)的倍数的 ...
- luogu P5366 [SNOI2017]遗失的答案
luogu 首先gcd为\(G\),lcm为\(L\),有可能出现的数(指同时是\(G\)的因数以及是\(L\)的倍数)可以发现只有几百个.如果选出的数要能取到gcd,那么对于每种质因子,都要有一个数 ...
- 洛谷$P5366\ [SNOI2017]$遗失的答案 数论+$dp$
正解:数论$dp$ 解题报告: 传送门$QwQ$ 考虑先质因数分解.所以$G$就相当于所有系数取$min$,$L$就相当于所有系数取$max$ 这时候考虑,因为数据范围是$1e8$,$1e8$内最多有 ...
- [SNOI2017]遗失的答案
题目 首先\(G,L\)肯定会满足\(G|L\),否则直接全部输出\(0\) 之后我们考虑一下能用到的质因数最多只有\(8\)个 同时我们能选择的数\(x\)肯定是\(L\)的约数,还得是\(G\)的 ...
随机推荐
- Autofac解耦事件总线
事件总线之Autofac解耦 事件总线是通过一个中间服务,剥离了常规事件的发布与订阅(消费)强依赖关系的一种技术实现.事件总线的基础知识可参考圣杰的博客[事件总线知多少] 本片博客不再详细概述事件总线 ...
- SSAS aggregation 的作用及其使用
作用: 聚合是为了解决查询在运行时的效率低下,在数据立方体部署的时候进行聚合,实际上是对数据立方体的预处理,方便以后查询.如若在部署时未进行聚合,则在以后每次查询时实际上都会进行一次集合的操作,等待结 ...
- 基于Flask开发web微信
1. 获取二维码 app.py import re import time import requests from flask import Flask,render_template app = ...
- eclipse打jar包解决第三方依赖包
在项目根目录下手动MANIFEST.MF(eclipse无法自动生成) MANIFEST.MF Manifest-Version: 1.0 Class-Path: lib/kafka-clients- ...
- ISCC的 Misc——WP
比赛已经结束了,自己做出来的题也不是很多,跟大家分享一下 Misc 第一题:What is that? 下载链接; 打开 解压 是一个图片 因为分值很少所以题和简单 观察图片是一个向下指的手 说明fl ...
- 《DSP using MATLAB》Problem 5.21
证明: 代码: %% ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...
- git使用之放弃本地修改
一,未使用 git add 缓存代码时. 可以使用 git checkout -- filepathname (比如: git checkout -- readme.md ,不要忘记中间的 “-- ...
- 线程---同步(synchronized)
实现线程同步的一种方式介绍: 思路: 首先,需要被协调的类,先实现线程,并重写run方法 然后,在被协调的类中私有化控制器,控制器实例化,由构造器带入. 其次,由控制器对象具体负责调用. 举例:循环输 ...
- maven(一)
Maven的简介 什么是maven 是apache下的一个开源项目,是纯java开发,并且只是用来管理java项目的 Maven好处 普通的传统项目 maven项目 分析:maven项目为什么这么小? ...
- 每天进步一点点-实例为导学-一个java对象序列化的例子
序列化和反序列化例子 如果我们想要序列化一个对象, (对象 转 序列)首先要创建某些OutputStream(如FileOutputStream.ByteArrayOutputStream等),然后将 ...