[洛谷P3338] [ZJOI2014]力
洛谷题目链接:P3338 [ZJOI2014]力
题目描述
给出n个数qi,给出Fj的定义如下:
\]
令Ei=Fi/qi,求Ei.
输入输出格式
输入格式:
第一行一个整数n。
接下来n行每行输入一个数,第i行表示qi。
输出格式:
n行,第i行输出Ei。
与标准答案误差不超过1e-2即可。
输入输出样例
输入样例#1:
5
4006373.885184
15375036.435759
1717456.469144
8514941.004912
1410681.345880
输出样例#1:
-16838672.693
3439.793
7509018.566
4595686.886
10903040.872
说明
对于30%的数据,n≤1000。
对于50%的数据,n≤60000。
对于100%的数据,n≤100000,0<qi<1000000000。
[spj 0.01]
题解:
首先考虑化式子(话说这玩意求的好像是电场强度诶).
\]
\]
不妨设\(b_i=\frac{1}{i^2}\),则有$$E_j=\sum_{i=0}{n-1}q_i*b_{j-i}-\sum_{i=j+1}{n-1}q_i*b_{i-j}$$
前面一半两个符号相乘的下标之和是一个常数,也就是如果将\(q,b\)看成多项式的话,那么这个乘积就可以做卷积.因为若\((a_0+a_1*x+a_2*x^2+...+a_{n-1}*x^{n-1})*(b_0+b_1*x+b_2*x^2+...+b_{n-1}*x^{n-1})=c_0+c_1*x+c_2*x^2+...+c^{2n-1}*x^{2n-1}\),则有\(c_k=\sum^k_{i=0}a_i*b_{k-i}\)也就是这样相乘可以使某一项的次数相同.
那么为了将后面的式子也转化成卷积的形式,我们可以将后面的\(q\)数组翻转一下,用\(q^{'}(q^{'}_i=q_{n-1-i})\)来代替,则有:$$E_j=\sum_{i=0}{n-1}q_i*b_{j-i}-\sum{n-1}{i=j+1}q^{'}{n-i-1}*b_{i-j}$$
那么后面那一半也变成了卷积的形式,就可以直接FFT求了.如果将\(b\)数组乘入\(q\)数组,那么最后的\(E_i\)对应着\(q_i-q^{'}_{n-i-1}\).
#include<bits/stdc++.h>
using namespace std;
const int N = 2e6+5;
const double eps = 1e-4;
const double pi = acos(-1.0);
typedef complex <double> comp;
int n, m, len = 0, r[N];
comp q1[N], q2[N], b1[N], b2[N];
void FFT(comp *A, int f){
for(int i = 0; i < m; i++) if(i < r[i]) swap(A[i], A[r[i]]);
for(int i = 1; i < m; i <<= 1){
for(int j = 0; j < m; j += (i<<1)){
comp wi(cos(pi/i), sin(f*pi/i)), x, y, w(1, 0);
for(int k = 0; k < i; k++, w *= wi){
x = A[j+k], y = w*A[i+j+k];
A[j+k] = x+y, A[i+j+k] = x-y;
}
}
}
if(f == -1) for(int i = 0; i < m; i++) A[i] /= m;
}
int main(){
ios::sync_with_stdio(false);
double x; cin >> n;
for(int i = 0; i < n; i++) cin >> x, q2[n-i-1] = q1[i] = x;
for(int i = 1; i <= n; i++) b1[i] = b2[i] = (double)(1.0/i/i);
for(m = 1; m <= n*2; m <<= 1) len++;
for(int i = 0; i < m; i++) r[i] = (r[i>>1]>>1) | ((i&1)<<(len-1));
cerr << endl;
FFT(q1, 1), FFT(b1, 1), FFT(q2, 1), FFT(b2, 1);
for(int i = 0; i < m; i++) q1[i] *= b1[i], q2[i] *= b2[i];
FFT(q1, -1), FFT(q2, -1);
for(int i = 0; i < n; i++) printf("%.3lf\n", q1[i].real()-q2[n-i-1].real());
return 0;
}
[洛谷P3338] [ZJOI2014]力的更多相关文章
- 洛谷 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]力(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}$ ...
- 洛谷 P3338 [ZJOI2014]力
题意简述 读入\(n\)个数\(q_i\) 设\(F_j = \sum\limits_{i<j}\frac{q_i\times q_j}{(i-j)^2 }-\sum\limits_{i> ...
- [bzoj3527] [洛谷P3338] [Zjoi2014]力
Description 给出n个数qi,给出Fj的定义如下: \[ F_j=\sum\limits_{i<j} \frac{q_iq_j}{(i-j)^2} - \sum\limits_{i&g ...
- 洛咕 P3338 [ZJOI2014]力
好久没写过博客了.. 大力推式子就行了: \(E_i=\sum_{j<i}\frac{q_j}{(i-j)^2}+\sum_{j>i}\frac{q_j}{(j-i)^2}\) 那么要转化 ...
- 【洛谷P3338】力
题目大意:求 \[ E_{j}=\sum_{i<j} \frac{q_{i}}{(i-j)^{2}}-\sum_{i>j} \frac{q_{i}}{(i-j)^{2}} \] 题解:可以 ...
- [Luogu P3338] [ZJOI2014]力 (数论 FFT 卷积)
题面 传送门: 洛咕 BZOJ Solution 写到脑壳疼,我好菜啊 我们来颓柿子吧 \(F_j=\sum_{i<j}\frac{q_i*q_j}{(i-j)^2}-\sum_{i>j} ...
- P3338 [ZJOI2014]力(FFT)
题目 P3338 [ZJOI2014]力 做法 普通卷积形式为:\(c_k=\sum\limits_{i=1}^ka_ib_{k-i}\) 其实一般我们都是用\(i=0\)开始的,但这题比较特殊,忽略 ...
- 【洛谷 P3338】 [ZJOI2014]力(FFT)
题目链接 \[\Huge{E_i=\sum_{j=1}^{i-1}\frac{q_j}{(i-j)^2}-\sum_{j=i+1}^{n}\frac{q_j}{(i-j)^2}}\] 设\(A[i]= ...
随机推荐
- python中argparse库的使用教程链接
这两篇文章详细介绍了argparse库的参数设置及使用包括位置参数与可选参数的用法 http://blog.csdn.net/guojuxia/article/details/44462381 htt ...
- BluetoothAdapter解析
这篇文章将会详细解析BluetoothAdapter的详细api, 包括隐藏方法, 每个常量含义. 一 BluetoothAdapter简介 1.继承关系 该类仅继承了Object类; 2.该类作用 ...
- java — 垃圾回收
1. 垃圾回收的意义 在java中,当没有对象指向原先分配给某个对象的内存的时候,这片内存就变成了垃圾,JVM的一个系统级线程就会自动释放这个内存块,垃圾回收意味着程序不再需要的对象是“无用的信息”, ...
- 【OpenGL】无法启动此程序,因为计算机中丢失 glut32.dll。尝试重新安装该程序以解决此问题。
运行OpenGL程序的时候报错,如图: 解决方法:把glut32.dll复制到C:\Windows\SysWOW64目录下,而不是像网上教程那样复制到C:\Windows\System32目录下. 原 ...
- 3dContactPointAnnotationTool开发日志(十六)
调了一上午才发现是把下面这个函数: private float DivideTriangle(int []triangle,out int []outTriangle,List<Vector ...
- mysql的my.cnf配置文件
[client]port = 3306default-character-set=utf8mb4socket = /var/run/mysqld/mysql.sock# user=david# pas ...
- (转)linux IO 内核参数调优 之 参数调节和场景分析
1. pdflush刷新脏数据条件 (linux IO 内核参数调优 之 原理和参数介绍)上一章节讲述了IO内核调优介个重要参数参数. 总结可知cached中的脏数据满足如下几个条件中一个或者多个的时 ...
- 《Effective C#》快速笔记(六)- - C# 高效编程要点补充
目录 四十五.尽量减少装箱拆箱 四十六.为应用程序创建专门的异常类 四十七.使用强异常安全保证 四十八.尽量使用安全的代码 四十九.实现与 CLS 兼容的程序集 五十.实现小尺寸.高内聚的程序集 这是 ...
- c运行时库,c标准库,Windows系统api的关系
原文地址:http://blog.csdn.net/seastars_sh/article/details/8233324 C运行库和C标准库的关系 C标准库,顾名思义既然是标准,就是由标准组织制定的 ...
- Maven 生命周期 和插件
1.3 生命周期1.3.1 什么是生命周期? Maven生命周期就是为了对所有的构建过程进行抽象和统一.包括项目清理.初始化.编译.打包.测试.部署等几乎所有构建步骤. 生命周期可以理解为构建工程的步 ...