P3338 [ZJOI2014]力(FFT)
题目
P3338 [ZJOI2014]力
做法
普通卷积形式为:\(c_k=\sum\limits_{i=1}^ka_ib_{k-i}\)
其实一般我们都是用\(i=0\)开始的,但这题比较特殊,忽略那部分,其他的直接按下标存下来,反正最后的答案是不变的
好了步入正题吧,我们定义 $$F_j=\sum\limits_{i<j}\dfrac{q_iq_j}{(i-j)2}-\sum\limits_{i<j}\dfrac{q_iq_j}{(i-j)2}$$
求\(E_i=\dfrac{F_i}{q_i}\)
显然$$E_j=\sum\limits_{i<j}\dfrac{q_i}{(i-j)2}-\sum\limits_{i<j}\dfrac{q_i}{(i-j)2}$$
\]
令\(f_i=q_i,g_i=\dfrac{1}{i^2}\),特别地,\(g_0=0\),则有:$$E_j=\sum_{i=1}{j-1}f_ig_{i-j}-\sum_{i=j+1}{n}f_ig_{i-j}$$
左边部分很简单就能化成卷积形式:$$\sum_{i=1}{j-1}f_ig_{i-j}=\sum_{i=1}{j-1}f_ig_{j-i}=\sum_{i=1}^{j}f_ig_{j-i}$$
右边部分:$$\sum\limits_{i=j+1}{n}f_ig_{i-j}=\sum\limits_{i=1}{n-j}f_{i+j}g_{i}$$
令\(p_i=f_{n-i}\),则\(p_{n-i-j}=f_{i+j}\),则有:$$\sum\limits_{i=1}{n-j}f_{i+j}g_{i}=\sum_{i=1}{n-j} p_{n-i-j}g_i$$
都化成卷积形式了直接FFT
My complete code
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
const double Pi=acos(-1.0);
const int maxn=300000;
struct complex{
double x,y;
complex (double xx=0,double yy=0){
x=xx,y=yy;
}
}f[maxn],p[maxn],g[maxn];
int n,limit,L;
int r[maxn];
complex operator + (complex x,complex y){
return complex(x.x+y.x,x.y+y.y);
}
complex operator - (complex x,complex y){
return complex(x.x-y.x,x.y-y.y);
}
complex operator * (complex x,complex y){
return complex(x.x*y.x-x.y*y.y,x.x*y.y+x.y*y.x);
}
inline void FFT(complex *A,int type){
for(int i=0;i<limit;++i)
if(i<r[i])
swap(A[i],A[r[i]]);
for(int mid=1;mid<limit;mid<<=1){
complex WN(cos(Pi/mid),type*sin(Pi/mid));
for(int R=mid<<1,j=0;j<limit;j+=R){
complex w(1,0);
for(int k=0;k<mid;++k,w=w*WN){
complex x=A[j+k],y=w*A[j+mid+k];
A[j+k]=x+y,
A[j+mid+k]=x-y;
}
}
}
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;++i){
scanf("%lf",&f[i].x),f[i].y=0,
g[i].x=(double)1.0/i/i;
p[n-i].x=f[i].x;
}
limit=1,L=0;
while(limit<n+n)
limit<<=1,
++L;
for(int i=0;i<limit;++i)
r[i]=(r[i>>1]>>1)|((i&1)<<(L-1));
FFT(f,1),FFT(p,1),FFT(g,1);
for(int i=0;i<limit;++i)
f[i]=f[i]*g[i];
for(int i=0;i<limit;++i)
p[i]=p[i]*g[i];
FFT(f,-1),FFT(p,-1);
for(int i=1;i<=n;++i)
printf("%.3lf\n",f[i].x/limit-p[n-i].x/limit);
return 0;
}/*
*/
P3338 [ZJOI2014]力(FFT)的更多相关文章
- P3338 [ZJOI2014]力 /// FFT 公式转化翻转
题目大意: https://www.luogu.org/problemnew/show/P3338 题解 #include <bits/stdc++.h> #define N 300005 ...
- [Luogu]P3338 [ZJOI2014]力(FFT)
题目描述 给出\(n\)个数\(q_i\),给出\(F_j\)的定义如下: \(F_j = \sum_{i<j}\frac{q_i q_j}{(i-j)^2 }-\sum_{i>j}\fr ...
- [Luogu P3338] [ZJOI2014]力 (数论 FFT 卷积)
题面 传送门: 洛咕 BZOJ Solution 写到脑壳疼,我好菜啊 我们来颓柿子吧 \(F_j=\sum_{i<j}\frac{q_i*q_j}{(i-j)^2}-\sum_{i>j} ...
- 洛谷 P3338 [ZJOI2014]力 解题报告
P3338 [ZJOI2014]力 题目描述 给出n个数qi,给出Fj的定义如下: \(F_j = \sum_{i<j}\frac{q_i q_j}{(i-j)^2 }-\sum_{i>j ...
- [洛谷P3338] [ZJOI2014]力
洛谷题目链接:P3338 [ZJOI2014]力 题目描述 给出n个数qi,给出Fj的定义如下: \[F_j = \sum_{i<j}\frac{q_i q_j}{(i-j)^2 }-\sum_ ...
- bzoj3527: [Zjoi2014]力 fft
bzoj3527: [Zjoi2014]力 fft 链接 bzoj 思路 但是我们求得是 \(\sum\limits _{i<j} \frac{q_i}{(i-j)^2}-\sum_{i> ...
- 【BZOJ】3527: [Zjoi2014]力 FFT
[参考]「ZJOI2014」力 - FFT by menci [算法]FFT处理卷积 [题解]将式子代入后,化为Ej=Aj-Bj. Aj=Σqi*[1/(i-j)^2],i=1~j-1. 令f(i)= ...
- 洛谷P3338 [ZJOI2014]力(FFT)
传送门 题目要求$$E_i=\frac{F_i}{q_i}=\sum_{j=1}^{i-1}\frac{q_j}{(i-j)^2}-\sum_{j=i+1}^n\frac{q_j}{(j-i)^2}$ ...
- 【bzoj3527】[Zjoi2014]力 FFT
2016-06-01 21:36:44 题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3527 我就是一个大傻叉 微笑脸 #include&l ...
随机推荐
- lua连接数据库之luasql ------ luasql连接mysql数据库 及 luasql源码编译
lua连接数据库不只luasql这个库,但目前更新最快的的貌似是这个luasql,他是开源的,支持的数据库功能如下: Connect to ODBC, ADO, Oracle, MySQL, SQLi ...
- apk文件反编译
apk文件的反编译,需要的工具apktool(反编译资源文件)和dex2jar-0.0.7.9-SNAPSHOT(反编译源码) 1. 下载相关软件 1)Apktool,下载地址:http://cod ...
- 正则表达式匹配 href 和text内容
string pattern = @"<a[^>]*href=(""(?<href>[^""]*)""|' ...
- MVC基础操作
C#-MVC基础操作-数据的展示及增删改.登录页面及状态保持一.数据展示1.View代码: <%@Page Language="C#" Inherits="Syst ...
- Docker Push 镜像到公共仓库
首选需要在https://hub.docker.com/上注册用户. 1.登录docker账号主要命令:docker login sudo docker login 2.推送镜像主要命令:docker ...
- orcad 里误给元件添加了属性,如何删除
1.先尝试点击delete property 2.第一步不行就右键选择filters----->remove current filter进行删除
- JWT简介json web token bear token
, "exp": 1502360328,(相差3600s) "nbf": , "jti": "R0Gd00AvOW259LGo&q ...
- 文件大小转换(b,kb,M,GB/TB)
//转换单位 setupSize(1111111111111); function setupSize($fileSize) { $size = sprintf("%u", $fi ...
- Linux守护进程简单介绍和实例具体解释
Linux守护进程简单介绍和实例具体解释 简单介绍 守护进程(Daemon)是执行在后台的一种特殊进程.它独立于控制终端而且周期性地执行某种任务或等待处理某些发生的事件.守护进程是一种非常实用的进程. ...
- Linux进程间通信(一) - 管道
管道(pipe) 普通的Linux shell都允许重定向,而重定向使用的就是管道. 例如:ps | grep vsftpd .管道是单向的.先进先出的.无结构的.固定大小的字节流,它把一个进程的标准 ...