[BZOJ]3527 力(ZJOI2014)
第一次背出FFT模板,在此mark一道裸题。
Description
给出n个数qi,给出Fj的定义如下:
令Ei=Fi/qi,求Ei。
Input
Output
n行,第i行输出Ei。与标准答案误差不超过1e-2即可。
Sample Input
5
4006373.885184
15375036.435759
1717456.469144
8514941.004912
1410681.345880
Sample Output
-16838672.693
3439.793
7509018.566
4595686.886
10903040.872
HINT
n ≤ 100000,0 < qi < 1000000000。
Solution
看到题目中 下标为j的项等于下标为i的项与下标为j±i的项的乘积之和,你应该会有所感觉吧。
设,那么 。
显然两边都是卷积的式子,所以两边分别做一次FFT就可以了。
然而我们再思考一下,发现两边的式子是可以合并的:
设,那么 就完全成立了。只要做一次FFT就够了。
时间复杂度O(nlogn)。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#define pi acos(-1)
#define MN 263005
using namespace std;
struct cp
{
double v,i;
friend cp operator+(const cp& a,const cp& b) {return (cp){a.v+b.v,a.i+b.i};}
friend cp operator-(const cp& a,const cp& b) {return (cp){a.v-b.v,a.i-b.i};}
friend cp operator*(const cp& a,const cp& b) {return (cp){a.v*b.v-a.i*b.i,a.v*b.i+a.i*b.v};}
}w[][MN],A[MN],B[MN],C[MN];
double a[MN];
int r[MN];
int N,n; void init(int n)
{
register int i,j,k;
for (N=;N<=n;N<<=); cp g=(cp){cos(pi*/N),sin(pi*/N)};
for (i=j=;i<N;r[++i]=j)
for (k=N>>;(j^=k)<k;k>>=);
w[][]=w[][]=(cp){,};
for (i=;i<N;++i) w[][i]=w[][i-]*g;
for (i=;i<N;++i) w[][i]=w[][N-i];
} void FFT(cp* a,bool g)
{
register int i,j,k;
for (i=;i<N;++i) if (r[i]<i) swap(a[i],a[r[i]]);
for (i=;i<N;i<<=)
for (j=;j<N;j+=(i<<))
for (k=;k<i;++k)
{
cp x=a[i+j+k]*w[g][N/(i<<)*k];
a[i+j+k]=a[j+k]-x;
a[j+k]=a[j+k]+x;
}
if (g) for (i=;i<N;++i) a[i].v/=N,a[i].i/=N;
} int main()
{
register int i;
scanf("%d",&n);
for (i=;i<=n;++i) scanf("%lf",&a[i]),A[i].v=a[i];
for (i=;i<n;++i)
B[n+i].v=(double)/i/i,B[n-i].v=(double)-/i/i;
init(n<<);
FFT(A,); FFT(B,);
for (i=;i<N;++i) C[i]=A[i]*B[i];
FFT(C,);
for (i=;i<=n;++i) printf("%.7lf\n",C[n+i].v);
}
Last Word
推荐miskcoo的关于学习FFT的blog:从多项式乘法到快速傅里叶变换。
[BZOJ]3527 力(ZJOI2014)的更多相关文章
- BZOJ 3527 力 | FFT
BZOJ 3527 力 | 分治 题意 给出数组q,$E_i = \sum_{i < j} \frac{q_i}{(i - j) ^ 2} - \sum_{i > j} \frac{q_i ...
- BZOJ 3527 【ZJOI2014】 力
题目链接:力 听说这道题是\(FFT\)板子题,于是我就来写了…… 首先可以发现这个式子:\[E_i=\sum_{j<i}\frac{q_j}{(i-j)^2}-\sum_{j>i}\fr ...
- BZOJ 3527 力
fft推下公式.注意两点: (1)数组从0开始以避免出错. (2)i*i爆long long #include<iostream> #include<cstdio> #incl ...
- 【BZOJ 3527】 3527: [Zjoi2014]力 (FFT)
3527: [Zjoi2014]力 Time Limit: 30 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 2003 Solved: 11 ...
- BZOJ 3527: [Zjoi2014]力
Description 求 \(E_i=\sum _{j=0}^{i-1} \frac {q_j} {(i-j)^2}-\sum _{j=i+1}^{n-1} \frac{q_j} {(i-j)^2} ...
- BZOJ 3527: [ZJOI2014]力(FFT)
BZOJ 3527: [ZJOI2014]力(FFT) 题意: 给出\(n\)个数\(q_i\),给出\(Fj\)的定义如下: \[F_j=\sum \limits _ {i < j} \fra ...
- ●BZOJ 3527 [Zjoi2014]力
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3527 题解: FFT求卷积. $$\begin{aligned}E_i&=\frac ...
- bzoj 3527 [Zjoi2014]力——FFT
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3527 把 q[ i ] 除掉.设 g[ i ] = i^2 ,有一半的式子就变成卷积了:另一 ...
- bzoj 3527 [Zjoi2014] 力 —— FFT
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3527 看了看TJ才推出来式子,还是不够熟练啊: TJ:https://blog.csdn.n ...
随机推荐
- listview 与 button 焦点 在item添加下列属性
android:descendantFocusability="blocksDescendants" http://zhaojianping.blog.51cto.com/7251 ...
- centos 安装配置 mysql
安装环境:CentOS7 64位 MINI版,安装MySQL5.7 1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo ...
- 前端面试题之css
1.请列出几个具有继承特性的css属性 font-family font-size color line-height text-align text-indent 2.阐述display: ...
- PV & PVC - 每天5分钟玩转 Docker 容器技术(150)
Volume 提供了非常好的数据持久化方案,不过在可管理性上还有不足. 拿前面 AWS EBS 的例子来说,要使用 Volume,Pod 必须事先知道如下信息: 当前 Volume 来自 AWS EB ...
- LeetCode & Q122-Best Time to Buy and Sell Stock II-Easy
Description: Say you have an array for which the ith element is the price of a given stock on day i. ...
- 用Java语言实现简单的词法分析器
编译原理中的词法分析算是很重要的一个部分,原理比较简单,不过网上大部分都是用C语言或者C++来编写,笔者近期在学习Java,故用Java语言实现了简单的词法分析器. 要分析的代码段如下: 输出结果如下 ...
- Python扩展模块——selenium的使用(定位、下载文件等)
想全面的使用selenium可以下载<selenium 2自动化测试实战-基于Python语言>PDF的电子书看看 我使用到了简单的浏览器操作,下载文件等功能... 推荐使用firefox ...
- ORM “杀器”之 JOOQ
ORM “杀器”之 JOOQ IN 后端编程,JAVA,敏捷开发,数据库 JOOQ是啥? JOOQ 是基于Java访问关系型数据库的工具包,轻量,简单,并且足够灵活,可以轻松的使用Java面向对象语法 ...
- HTTP协议扫盲(七)请求报文之 GET、POST-FORM 和 POST-FILE
一.get 1.页面代码 2.请求报文 3.小结 get请求没有报文体,所以请求报文没有content-type url上的query参数param11=val11¶m12=val12 ...
- ELK学习总结(4-2)关于导入数据
用REST API的_bulk来批量插入,可以达到5到10w条每秒 把数据写进json文件,然后再通过批处理,执行文件插入数据: 1.先定义一定格式的json文件,文件不能过大,过大会报错 2.后用c ...