第一次背出FFT模板,在此mark一道裸题。

Description

  给出n个数qi,给出Fj的定义如下:

  

  令Ei=Fi/qi,求Ei。

Input

  第一行一个整数n。
  接下来n行每行输入一个数,第i行表示qi。

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)的更多相关文章

  1. BZOJ 3527 力 | FFT

    BZOJ 3527 力 | 分治 题意 给出数组q,$E_i = \sum_{i < j} \frac{q_i}{(i - j) ^ 2} - \sum_{i > j} \frac{q_i ...

  2. BZOJ 3527 【ZJOI2014】 力

    题目链接:力 听说这道题是\(FFT\)板子题,于是我就来写了…… 首先可以发现这个式子:\[E_i=\sum_{j<i}\frac{q_j}{(i-j)^2}-\sum_{j>i}\fr ...

  3. BZOJ 3527 力

    fft推下公式.注意两点: (1)数组从0开始以避免出错. (2)i*i爆long long #include<iostream> #include<cstdio> #incl ...

  4. 【BZOJ 3527】 3527: [Zjoi2014]力 (FFT)

    3527: [Zjoi2014]力 Time Limit: 30 Sec  Memory Limit: 256 MBSec  Special JudgeSubmit: 2003  Solved: 11 ...

  5. 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} ...

  6. BZOJ 3527: [ZJOI2014]力(FFT)

    BZOJ 3527: [ZJOI2014]力(FFT) 题意: 给出\(n\)个数\(q_i\),给出\(Fj\)的定义如下: \[F_j=\sum \limits _ {i < j} \fra ...

  7. ●BZOJ 3527 [Zjoi2014]力

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3527 题解: FFT求卷积. $$\begin{aligned}E_i&=\frac ...

  8. bzoj 3527 [Zjoi2014]力——FFT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3527 把 q[ i ] 除掉.设 g[ i ] = i^2 ,有一半的式子就变成卷积了:另一 ...

  9. bzoj 3527 [Zjoi2014] 力 —— FFT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3527 看了看TJ才推出来式子,还是不够熟练啊: TJ:https://blog.csdn.n ...

随机推荐

  1. C++数据结构中的基本算法排序

    冒泡排序 基本思想:两两比较待排序的数,发现反序时交换,直到没有反序为止. public static void BubbleSort(int[] R) { for (int i = 0; i < ...

  2. bzoj千题计划217:bzoj2333: [SCOI2011]棘手的操作

    http://www.lydsy.com/JudgeOnline/problem.php?id=2333 读入所有数据,先模拟一遍所有的合并操作 我们不关心联通块长什么样,只关心联通块内有谁 所以可以 ...

  3. Microsoft dynamic 批量更新

    //批量处理 ExecuteMultipleRequest multipleRequest = new ExecuteMultipleRequest() { Settings = new Execut ...

  4. 基于python的统计公报关键数据爬取 update

    由于之前存在的难以辨别市本级,全市相关数据的原因,经过考虑采用 把含有关键词的字段全部提取进行人工辨别的方法 在其余部分不改变的情况下,更改test部分 def test(real_Title,rea ...

  5. Android P专区免费开放 -- 同样的Android,不同的体验

    2018年3月8日,Google推出了Android P Preview版本,并提供官方镜像下载. 为了让广大开发者能够及时了解Android P的新功能特性,提前为您的app进行良好适配,WeTes ...

  6. Oracle 存储过程简单语法

    一.无参数的存储过程 --创建存储过程create or replace procedure getdate as datetime varchar2(); begin select to_char( ...

  7. c++中的类之构造函数

    一.构造函数的缘由 本文我们主要来讲解c++中类的构造函数,其中涉及了深拷贝和浅拷贝的问题,这也是在面试笔试中经常会碰到的问题.如果您是第一次听说构造函数,可能会觉得这个名字有点高大上,而它却和实际中 ...

  8. 使用生成器把Kafka写入速度提高1000倍

    title: 使用生成器把Kafka写入速度提高1000倍 toc: true comment: true date: 2018-04-13 21:35:09 tags: ['Python', '经验 ...

  9. Flask博客开发——登录验证码

    这部分为Flask博客的登录页面加个验证码.使用了PIL模块生成验证码图片,并通过Flask的session机制,进行验证码验证. 1.生成验证码 使用string模块:string.ascii_le ...

  10. 在 .NET Core 中使用 DiagnosticSource 记录跟踪信息

    前言 最新一直在忙着项目上的事情,很久没有写博客了,在这里对关注我的粉丝们说声抱歉,后面我可能更多的分享我们在微服务落地的过程中的一些经验.那么今天给大家讲一下在 .NET Core 2 中引入的全新 ...