我们看一下这个函数,很容易就把他化为 E=sigma(aj/(i-j)/(i-j))(i>j)-sigma(aj/(i-j)/(i-j))(j>i)

把它拆成两半,可以发现分子与分母下标相加总为i

也就是说,例如左边, 可以表示成g(x)= f(i)*F(x-i) (i<x) 也就是卷积了

可以轻易的构造出 f(i)= ai F(i)=1/i/i FFT就行了

右边的话,吧f(i)给倒过来就行了 (f(i)=an-i)

最后的答案 ansi=g(i)-G(n-i-1)

ok了

最近发现自己写环套树老写渣,找几道题来练练~~

CODE:

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
struct com{ //自定义复数类
 double r,i;
 com(double real=0.0,double imag=0.0){
  r=real;i=imag;
 }
 com operator +(const com x){
  return com(x.r+r,x.i+i);
 }
 com operator -(const com x){
  return com(r-x.r,i-x.i);
 }
 com operator *(const com x){
  return com(x.r*r-x.i*i,r*x.i+i*x.r);
 }
};
#define maxn 400100 //答案的位数
#define pi acos(-1.0)
com a[maxn*2],b[maxn*2],c[maxn*2],d[maxn*2];;
bool bo[maxn*2];
int bitrec(com *x,int l){
 memset(bo,0,sizeof(bo));
 for (int i=1;i<l;i++){
  if (bo[i]) continue;
  int m=(int)log2(l)+0.5;
  int y=i,z=0;
  while (m--){
   z<<=1;
   z|=y&1;
   y>>=1;
  }
  bo[z]=bo[i]=1;
  swap(x[z],x[i]);
 }
 return 0;
}
int fft(com *x,int l,double o){
 bitrec(x,l);
 for (int i=2;i<=l;i<<=1){
  com w(cos(2.0*o*pi/i),sin(2.0*o*pi/i));
  for (int j=0;j<l;j+=i){
   com t(1.0,0.0);
   for (int k=j;k<j+(i>>1);k++){
    com u=x[k],v=x[k+(i>>1)]*t;
    x[k]=u+v;
    x[k+(i>>1)]=u-v;
    t=t*w;
   }
  }
 }
 if (o==-1) {
  for (int i=0;i<l;i++) x[i].r/=l;
 }
 return 0;
}
double x[maxn];
int main(){
 int n;
 scanf("%d",&n);int l=1;
 while (l<=n*2) l<<=1;
 for (int i=0;i<n;i++) {
  scanf("%lf",&x[i]);
  a[i]=com(x[i],0);
 }
 for (int i=n;i<l;i++) a[i]=com(0,0);
 for (int i=1;i<n;i++) b[i]=com(1.0/i/i,0);
 for (int i=n;i<l;i++) b[i]=com(0,0);
 b[0]=com(0,0);
 fft(a,l,1);
 fft(b,l,1);
 for (int i=0;i<l;i++) c[i]=a[i]*b[i];
 fft(c,l,-1);
 for (int i=0;i<n;i++) a[i]=com(x[n-i-1],0);
 for (int i=n;i<=l;i++) a[i]=com(0,0);
 fft(a,l,1);
 for (int i=0;i<l;i++) d[i]=a[i]*b[i];
 fft(d,l,-1);
 for (int i=0;i<n;i++) printf("%.3lf\n",(c[i].r-d[n-i-1].r));
 return 0;
}

BZOJ 3527: [Zjoi2014]力(FFT)的更多相关文章

  1. bzoj 3527 [Zjoi2014]力——FFT

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

  2. bzoj 3527 [Zjoi2014] 力 —— FFT

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

  3. BZOJ 3527 [Zjoi2014]力 ——FFT

    [题目分析] FFT,构造数列进行卷积,挺裸的一道题目诶. 还是写起来并不顺手,再练. [代码] #include <cmath> #include <cstdio> #inc ...

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

    [参考]「ZJOI2014」力 - FFT by menci [算法]FFT处理卷积 [题解]将式子代入后,化为Ej=Aj-Bj. Aj=Σqi*[1/(i-j)^2],i=1~j-1. 令f(i)= ...

  5. ●BZOJ 3527 [Zjoi2014]力

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

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

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

  7. 数学(FFT):BZOJ 3527 [Zjoi2014]力

    题目在这里:http://wenku.baidu.com/link?url=X4j8NM14MMYo8Q7uPE7-7GjO2_TXnMFA2azEbBh4pDf7HCENM3-hPEl4mzoe2w ...

  8. bzoj 3527: [Zjoi2014]力 快速傅里叶变换 FFT

    题目大意: 给出n个数\(q_i\)定义 \[f_i = \sum_{i<j}{\frac{q_iq_j}{(i-j)^2}} - \sum_{i>j}\frac{q_iq_j}{(i-j ...

  9. bzoj 3527: [Zjoi2014]力【FFT】

    大力推公式,目标是转成卷积形式:\( C_i=\sum_{j=1}^{i}a_jb_{i-j} \) 首先下标从0开始存,n-- \[ F_i=\frac{\sum_{j<i}\frac{q_j ...

随机推荐

  1. STM32中的位带(bit-band)操作(转)

    源:STM32中的位带(bit-band)操作 支持了位带操作后,可以使用普通的加载/存储指令来对单一的比特进行读写.在 CM3 中,有两个区中实现了位带.其中一个是 SRAM 区的最低 1MB 范围 ...

  2. RoundedImageView使用吐槽心得(RoundedImageView与Glide加载图片,第一次加载无法圆角问题)

    最近使用的时候发现一个问题, RoundedImageView与Glide搭配使用的时候,第一次加载图片(内存中没有),后图片无法圆角,后来尝试各种改,最后想到了一个办法,就是让Glide加载图片的 ...

  3. FAB、TextInputLayout及Snackbar笔记

    FloatingActionButton 由于FloatingActionButton是重写ImageView的,所有FloatingActionButton拥有ImageView的一切属性. 控制F ...

  4. jQuery之事件移除

    当事件执行完了,想取消事件的效果可以通过一定的办法来处理.比如bind()方法,可以通过unbind()方法来移除事件的效果. 比如下面的一个案例: <script type="tex ...

  5. AndroidManifest.xml文件

    AndroidManifest.xml常用标签解读 1.全局篇(包名,版本信息) 2.组件篇(四大组件) Activity Service Content Provider Broadcast Rec ...

  6. C++中vector 容器的基本操作

    vector是一种简单高效的容器,具有自动内存管理功能.对于大小为n的vector容器,它的元素下标是0~n-1. vector有二个重要方法:     begin(): 返回首元素位置的迭代器.   ...

  7. spark Intellij IDEA开发环境搭建

    (1)创建Scala项目 File->new->Project,如下图 选择Scala 然后next 其中Project SDK指定安装的JDK,Scala SDK指定安装的Scala(这 ...

  8. PHP mysqli连接MySQL数据库

    1. 开启PHP的API支持 (1)首先修改您的php.ini的配置文件.查找下面的语句:;extension=php_mysqli.dll将其修改为:extension=php_mysqli.dll ...

  9. Stanford机器学习课程之一——引言

    Andrew Ng的Machine Learning课程,在网易公开课上有中文版视频http://v.163.com/special/opencourse/machinelearning.html,六 ...

  10. Android开发系列之Context

    相信大家对于Context应该非常熟悉,但是Context到底是什么意思呢?到底指的是什么东西呢?我们可以理解为当前对象在程序中所处的一个环境,一个与系统交互的过程.Android系统的上下文对象,即 ...