洛谷题目链接:P3338 [ZJOI2014]力

题目描述

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

\[F_j = \sum_{i<j}\frac{q_i q_j}{(i-j)^2 }-\sum_{i>j}\frac{q_i q_j}{(i-j)^2 }
\]

令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]

题解:

首先考虑化式子(话说这玩意求的好像是电场强度诶).

\[F_j = \sum_{i<j}\frac{q_i q_j}{(i-j)^2 }-\sum_{i>j}\frac{q_i q_j}{(i-j)^2 }, E_j=\frac{F_j}{q_j}
\]

\[E_j=\sum_{i=0}^{n-1}q_i*\frac{1}{(j-i)^2}-\sum_{i=j+1}^{n-1}q_i*\frac{1}{(i-j)^2}
\]

不妨设\(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]力的更多相关文章

  1. 洛谷 P3338 [ZJOI2014]力 解题报告

    P3338 [ZJOI2014]力 题目描述 给出n个数qi,给出Fj的定义如下: \(F_j = \sum_{i<j}\frac{q_i q_j}{(i-j)^2 }-\sum_{i>j ...

  2. 洛谷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}$ ...

  3. 洛谷 P3338 [ZJOI2014]力

    题意简述 读入\(n\)个数\(q_i\) 设\(F_j = \sum\limits_{i<j}\frac{q_i\times q_j}{(i-j)^2 }-\sum\limits_{i> ...

  4. [bzoj3527] [洛谷P3338] [Zjoi2014]力

    Description 给出n个数qi,给出Fj的定义如下: \[ F_j=\sum\limits_{i<j} \frac{q_iq_j}{(i-j)^2} - \sum\limits_{i&g ...

  5. 洛咕 P3338 [ZJOI2014]力

    好久没写过博客了.. 大力推式子就行了: \(E_i=\sum_{j<i}\frac{q_j}{(i-j)^2}+\sum_{j>i}\frac{q_j}{(j-i)^2}\) 那么要转化 ...

  6. 【洛谷P3338】力

    题目大意:求 \[ E_{j}=\sum_{i<j} \frac{q_{i}}{(i-j)^{2}}-\sum_{i>j} \frac{q_{i}}{(i-j)^{2}} \] 题解:可以 ...

  7. [Luogu P3338] [ZJOI2014]力 (数论 FFT 卷积)

    题面 传送门: 洛咕 BZOJ Solution 写到脑壳疼,我好菜啊 我们来颓柿子吧 \(F_j=\sum_{i<j}\frac{q_i*q_j}{(i-j)^2}-\sum_{i>j} ...

  8. P3338 [ZJOI2014]力(FFT)

    题目 P3338 [ZJOI2014]力 做法 普通卷积形式为:\(c_k=\sum\limits_{i=1}^ka_ib_{k-i}\) 其实一般我们都是用\(i=0\)开始的,但这题比较特殊,忽略 ...

  9. 【洛谷 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]= ...

随机推荐

  1. 团队作业week9 情景测试

    一.使用人群:学生.计算机工作者.对计算机感兴趣的人 1.学生:学生是学霸系统的主要用户.学生一般会通过网络寻找与自己的课程,作业有关的信息.首先,可以通过我们的搜索功能在我们的数据库中寻找我们从网络 ...

  2. onethink框架显示Access denied for user 'root'@'localhost' (using password: NO)

    本地开发的时候使用的用户名是root,密码为空,它会生成两份.一份在Common/config.php里面,还有一份在Application\User\Conf/config.php 在linux环境 ...

  3. 20162328蔡文琛week02

    学号 20162328 <程序设计与数据结构>第2周学习总结 教材学习内容总结 这周学习了课本中的第二章内容,比起第一章,本章难度有略微底稿,从刚开始的显示字符转变为简单的加减乘除运算,经 ...

  4. 哈希表 STL map

    计数排序时我们使用一个数组来记录出现的数字的次数,而当数据范围太大时,无法建立一个那么大地数组(而且可能空间利用率很低,太浪费),此时可以改用hash table . binary search tr ...

  5. TCP系列40—拥塞控制—3、慢启动和拥塞避免概述

    本篇中先介绍一下慢启动和拥塞避免的大概过程,下一篇中将会给出多个linux下reno拥塞控制算法的wireshark示例,并详细解释慢启动和拥塞避免的过程. 一.慢启动(slow start) 一个T ...

  6. Qt在VS(Visual Studio)中使用

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:Qt在VS(Visual Studio)中使用     本文地址:https://www.te ...

  7. Redis Cluster实现原理

    一.Redis Cluster主要特性和设计     集群目标 1)高性能和线性扩展,最大可以支撑到1000个节点:Cluster架构中无Proxy层,Master与slave之间使用异步replic ...

  8. JAVA的泛型与反射的联合应用

    通过泛型与反射的结合,可以编写框架来使开发更容易,这里演示的是BaseDao部分的简单使用. BaseDao部分代码: public abstract class BaseDao<T>{ ...

  9. matlab isfield

    isfield 函数功能:判断输入是否是结构体数组的域(成员). 调用格式: tf=isfield(S,'fieldname') 检查结构体S是否包含由fieldname指定的域,如果包含,返回逻辑1 ...

  10. P1807 最长路_NOI导刊2010提高(07)

    题目描述 设G为有n个顶点的有向无环图,G中各顶点的编号为1到n,且当为G中的一条边时有i < j.设w(i,j)为边的长度,请设计算法,计算图G中<1,n>间的最长路径. 输入输出 ...