BZOJ 3527: [Zjoi2014]力(FFT)
我们看一下这个函数,很容易就把他化为 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)的更多相关文章
- 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 ...
- BZOJ 3527 [Zjoi2014]力 ——FFT
[题目分析] FFT,构造数列进行卷积,挺裸的一道题目诶. 还是写起来并不顺手,再练. [代码] #include <cmath> #include <cstdio> #inc ...
- 【BZOJ】3527: [Zjoi2014]力 FFT
[参考]「ZJOI2014」力 - FFT by menci [算法]FFT处理卷积 [题解]将式子代入后,化为Ej=Aj-Bj. Aj=Σqi*[1/(i-j)^2],i=1~j-1. 令f(i)= ...
- ●BZOJ 3527 [Zjoi2014]力
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3527 题解: FFT求卷积. $$\begin{aligned}E_i&=\frac ...
- BZOJ 3527: [ZJOI2014]力(FFT)
BZOJ 3527: [ZJOI2014]力(FFT) 题意: 给出\(n\)个数\(q_i\),给出\(Fj\)的定义如下: \[F_j=\sum \limits _ {i < j} \fra ...
- 数学(FFT):BZOJ 3527 [Zjoi2014]力
题目在这里:http://wenku.baidu.com/link?url=X4j8NM14MMYo8Q7uPE7-7GjO2_TXnMFA2azEbBh4pDf7HCENM3-hPEl4mzoe2w ...
- 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 ...
- 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 ...
随机推荐
- UWP_小说在线阅读器:功能要求与技术要求
学了WP开发也有一年了,也没做过什么软件的.17年进发UWP,锻炼自己一下.做一个开源的小说阅读器吧. 既然开发一个软件.所以要设计一下吧. 功能要求: 可能要用到的技术,这个吗,这就是遇到问题在解决 ...
- bitmap 加载的时候出现OOM,nullpointer
1.OOM :对图片进行压缩,效果还不错:http://182.92.150.15:9876/static/server/topic_user/8068/201506/e5b37fec-0919-11 ...
- js模块化开发——require.js的用法详细介绍(含jsonp)
RequireJS的目标是鼓励代码的模块化,它使用了不同于传统<script>标签脚本加载步骤.可以用它回事.优化代码,但其主要的目的还是为了代码的模块化.它鼓励在使用脚本以moudle ...
- git 配置SSH免密
1.安装TortoiseGit(比较简单,直接在官网上下载安装包安装) 2.打开下图标识 点击 generate按钮 生成key(需要等一会) 3.生成Key保存成.ppk文件,记得存放路径,(建 ...
- mfix模拟流化床燃烧帮助收敛的方法
1.在反应速率里用rate_limit函数:2.初始床料中可以添加一部分碳和灰.下面给出详细解释: 1.c3m生成的化学反应速率中有一个这样的函数: double precision function ...
- Flash中图片的逐步加载
在Flash中,有Loader类,可以从外部载入一张图片(或swf文件).但是有个不好的地方就是,不像浏览器那样一边下载一边显示.所幸的是,Flash提供了Loader.loadBytes方法和URL ...
- Java线程:线程交互
一.基础知识 java.lang.Object的类的三个方法: void notify():唤醒在此对象监视器上等待的单个线程. void notifyAll():唤醒在此对象监视器上等待的所有线程. ...
- 使用IntelliJ IDEA开发SpringMVC网站(一)开发环境
使用IntelliJ IDEA开发SpringMVC网站(一)开发环境 摘要: 主要讲解初期的开发环境搭建,Maven的简单教学. 访问GitHub下载最新源码:https://github.com/ ...
- node源码详解(五) —— 在main函数之前 —— js和C++的边界,process.binding
本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/nodesource5 本博客同步在https://cnodejs.o ...
- SDWebImage源码解读之SDWebImageManager
第九篇 前言 SDWebImageManager是SDWebImage中最核心的类了,但是源代码确是非常简单的.之所以能做到这一点,都归功于功能的良好分类. 有了SDWebImageManager这个 ...