bzoj 4929: 第三题
Description
Input
Output
#include<bits/stdc++.h>
typedef std::vector<int> pol;
typedef long long i64;
typedef unsigned long long u64;
const int P=;
int max(int a,int b){return a>b?a:b;}
template<int p>
i64 pw(int a,int n){
if(n<)n+=p-;
i64 v=;
for(;n;n>>=,a=i64(a)*a%p)if(n&)v=v*a%p;
return v;
}
int N,K,r[<<|];
typedef double ld;
struct cplx{
ld a,b;
cplx(ld _x=,ld _y=):a(_x),b(_y){}
cplx operator+(cplx w){return cplx(a+w.a,b+w.b);}
cplx operator-(cplx w){return cplx(a-w.a,b-w.b);}
cplx operator*(cplx w){return cplx(a*w.a-b*w.b,a*w.b+b*w.a);}
}A[<<|],B[<<|],*Es[][],C[<<|],D[<<|];
void pre(int n){
for(N=,K=;N<n;N<<=,++K);
for(int i=;i<N;++i)r[i]=r[i>>]>>|(i&)<<K;
memset(A,,sizeof(cplx)*N);
memset(B,,sizeof(cplx)*N);
memset(C,,sizeof(cplx)*N);
memset(D,,sizeof(cplx)*N);
}
const ld pi=acos(-);
void dft(cplx*a,int t){
for(int i=;i<N;++i)if(i<r[i])std::swap(a[i],a[r[i]]);
for(int i=,z=;i<N;i<<=,++z){
if(!Es[t==][z]){
cplx*E=Es[t==][z]=new cplx[i];
for(int j=;j<i;++j)E[j]=cplx(cos(j*pi/i),t*sin(j*pi/i));
}
cplx*E=Es[t==][z];
for(int j=;j<N;j+=i<<){
cplx*b=a+j,*c=b+i;
for(int k=;k<i;++k){
cplx x=b[k],y=c[k]*E[k];
b[k]=x+y;
c[k]=x-y;
}
}
}
if(t==-)for(int i=;i<N;++i)a[i].a/=N;
}
void mul(cplx*a,cplx*b){
for(int i=;i<N;++i)a[i]=a[i]*b[i];
}
void mov(const pol&x,cplx*a){
for(int i=;i<x.size();++i)a[i].a=x[i];
}
void mov(cplx*a,const pol&_x){
pol&x=const_cast<pol&>(_x);
for(int i=;i<x.size();++i)x[i]=i64(a[i].a+0.49)%P;
}
void mov(const pol&x,int*a){
memcpy(a,x.data(),x.size()*sizeof(int));
}
void mov(int*a,const pol&_x){
pol&x=const_cast<pol&>(_x);
memcpy(x.data(),a,x.size()*sizeof(int));
}
void chk(pol&w){
int p=w.size();
while(p&&!w[p-])--p;
w.resize(p);
}
void rev(pol&w){
std::reverse(w.data(),w.data()+w.size());
}
u64 _c[];
pol operator*(const pol&a,const pol&b){
pol c(a.size()+b.size()-);
if(c.size()<=){
const int*as=a.data(),ap=a.size(),*bs=b.data(),bp=b.size();
int*cs=c.data();
for(int i=;i<c.size();++i)_c[i]=;
for(int i=;i<ap;++i)for(int j=;j<bp;++j)_c[i+j]+=u64(as[i])*bs[j];
for(int i=;i<c.size();++i)cs[i]=_c[i]%P;
}else if(c.size()<=){
pre(c.size());
mov(a,A),mov(b,B);
dft(A,),dft(B,);
mul(A,B);
dft(A,-);
mov(A,c);
}else{
pre(c.size());
for(int i=;i<a.size();++i){
A[i]=a[i]>>;
B[i]=a[i]&;
}
for(int i=;i<b.size();++i){
C[i]=b[i]>>;
D[i]=b[i]&;
}
dft(A,);dft(B,);dft(C,);dft(D,);
for(int i=;i<N;++i){
cplx v1=A[i]*C[i];
cplx v2=A[i]*D[i]+B[i]*C[i];
cplx v3=B[i]*D[i];
A[i]=v1;
B[i]=v2;
C[i]=v3;
}
dft(A,-);dft(B,-);dft(C,-);
for(int i=;i<c.size();++i){
c[i]=((i64(A[i].a+0.49)<<)+(i64(B[i].a+0.49)<<)+i64(C[i].a+0.49))%P;
}
}
chk(c);
return c;
}
pol operator*(const pol&w,int x){
pol a(w);
for(int i=;i<a.size();++i)a[i]=i64(a[i])*x%P;
return a;
}
pol operator-(const pol&a,const pol&b){
pol c(max(a.size(),b.size()));
mov(a,c.data());
for(int i=;i<b.size();++i)c[i]=(c[i]-b[i]+P)%P;
chk(c);
return c;
}
pol inv(pol a){
if(a.size()==){
a.resize();
a[]=pw<P>(a[],P-);
return a;
}
pol b=inv(pol(a.data(),a.data()+(a.size()-)/+));
pol c=b*b*a;
c=b*-c;
c.resize(a.size());
return c;
}
pol operator/(pol a,pol b){
chk(a),chk(b);
rev(a),rev(b);
int sz=a.size()-b.size()+;
b.resize(sz);
pol c=a*inv(b);
c.resize(sz);
rev(c);
chk(c);
return c;
}
pol operator%(const pol&a,const pol&b){
if(a.size()<b.size())return a;
return a-a/b*b;
}
int cal(const pol&w,i64 x){
int y=;
for(int p=w.size()-;p>=;--p)y=(y*x+w[p])%P;
return y;
}
int n,b,c,d,e,a[],as[];
struct Q{int x,id;}qs[];
bool operator<(Q a,Q b){return a.x<b.x;}
pol tr[];
void calc0(int w,int L,int R){
if(L==R){
tr[w]=pol();
tr[w][]=;
tr[w][]=(P-qs[L].x)%P;
return;
}
int M=(L+R)/;
calc0(w<<,L,M);
calc0(w<<^,M+,R);
tr[w]=tr[w<<]*tr[w<<^];
}
void calc1(const pol&a,int w,int L,int R){
if(R-L<=){
for(int i=L;i<=R;++i)as[qs[i].id]=cal(a,qs[i].x);
return;
}
int M=(L+R)/;
calc1(a%tr[w<<],w<<,L,M);
calc1(a%tr[w<<^],w<<^,M+,R);
}
int main(){
scanf("%d%d%d%d%d",&n,&b,&c,&d,&e);
for(int i=;i<n;++i)scanf("%d",a+i);
for(int i=;i<n;++i){
qs[i].x=(b*pw<P>(c,*i)+d*pw<P>(c,*i)+e)%P;
qs[i].id=i;
}
std::sort(qs,qs+n);
tr[]=pol(n);
mov(a,tr[]);
calc0(,,n-);
calc1(tr[],,,n-);
for(int i=;i<n;++i)printf("%d\n",(as[i]+P)%P);
return ;
}
bzoj 4929: 第三题的更多相关文章
- shanquan2的两年三题系列
好像只有2个月就退役啦 不管了,先说一下哪三题:多点求值.lcm.替罪羊树(bzoj3065) [upd0]2016.3.29 多点求值A掉啦,myy卡常数sxbk(不是说好的是shanquan2出的 ...
- Java-集合-第三题 有如下Student 对象, private String name; private int age; private int score; private String classNum; 其中,classNum 表示学生的班号,例如“class05”。 有如下List List list = new ArrayList(); l
第三题 有如下Student 对象, private String name; private int age; private int score; private String classNum; ...
- NOIP 2008提高组第三题题解by rLq
啊啊啊啊啊啊今天已经星期三了吗 那么,来一波题解吧 本题地址http://www.luogu.org/problem/show?pid=1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们 ...
- NOIP2008提高组(前三题) -SilverN
此处为前三题,第四题将单独发布 火柴棒等式 题目描述 给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0 ...
- 《学习OpenCV》练习题第四章第三题b
#include <highgui.h> #include <cv.h> #include "opencv_libs.h" /* *<学习OpenCV ...
- 《学习OpenCV》练习题第四章第三题a
#include <highgui.h> #include <cv.h> #include "opencv_libs.h" #pragma comment ...
- 阿里聚安全攻防挑战赛第三题Android PwnMe解题思路
阿里聚安全攻防挑战赛第三题Android PwnMe解题思路 大家在聚安全挑战赛正式赛第三题中,遇到android app 远程控制的题目.我们今天带你一探究竟,如何攻破这道题目. 一.题目 购物应用 ...
- 剑指offier第三题
package 剑指office; /* * 第三题二维数组查找 * 在一个二维数组中,每一行都按照从左到右递增的顺序排序, * 每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维 ...
- NOIP2005-普及组复赛-第三题-采药
题目描述 Description 辰辰是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师.为此,他想拜附近最有威望的医师为师.医师为了判断他的资质,给他出了一个难题.医师把他带到一个到处都是草药的山 ...
随机推荐
- MinGW的gdb调试
MinGW(Minimalist GNU for Windows)提供了一套简单方便的Windows下的基于GCC程序开发环境.MinGW收集了一系列免费的Windows是用的头文件和库文件: ...
- HP-UNIX操作系统root账号被锁定的两种解决方法
方法一:到单用户取消trusted system, 重新激活账户 a.重起机器,自检完成后,会出现这一行"To discontinue, press any key in 10 second ...
- STL标准库-Tuple
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 在前面我介绍过一次tuple,今天在书上也看到了tuple,那就在写一次吧. tuple(元组),他的内部可以放任意类型的变量( ...
- bootstrap-treeview 自定义实现双击事件
bootstrap-treeview是一款效果非常酷的基于bootstrap的jQuery多级列表树插件.该jQuery插件基于Twitter Bootstrap,以简单和优雅的方式来显示一些继承树结 ...
- React 源码剖析系列 - 不可思议的 react diff
简单点的重复利用已有的dom和其他REACT性能快的原理. key的作用和虚拟节点 目前,前端领域中 React 势头正盛,使用者众多却少有能够深入剖析内部实现机制和原理. 本系列文章希望通过剖析 ...
- Css的优先权问题
看这篇文章之前,对这个问题一直没深入研究,导致有时候遇到一些问题会很麻烦,看到这篇文章让我茅塞顿开,转帖回来保存一下以便今后复习. 发现很多朋友对 CSS 的优先权不甚了解,规则很简单.需要说明的一点 ...
- ubuntu 部署wordPress
准备 LAMP 环境 1.安装 Apache2 sudo apt-get install apache2 -y 安装好后,您可以通过访问服务器IP地址 x.x.x.x 查看到 “it works” 界 ...
- setTimeout设置为0的作用
调用方式:iTimerID = window.setTimeout(vCode, iMilliSeconds [, sLanguage])功能:Evaluates an expression afte ...
- Patch打补丁学习笔记
1.基本命令语法: patch [-R] {-p(n)} [--dry-run] < patch_file_name p:为path的缩写. n:指将patch文件中的path第n条’/’及其左 ...
- hasura graphql 集成pipelinedb测试
实际上因为pipelinedb 是原生支持pg的,所以应该不存在太大的问题,以下为测试 使用doker-compose 运行 配置 docker-compose 文件 version: '3.6' s ...