题面

传送门:


Solution

写到脑壳疼,我好菜啊

我们来颓柿子吧

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

\(q_j\)与\(i\)没有半毛钱关系,提到外面去

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

左右同时除以\(q_j\)

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

我们设\(f(i)=q(i),g(i)=\frac{1}{i^2}\),有

\(E_j=\sum_{i=1}^{j-1}f(i)*g(i-j)-\sum_{i=j+1}^{n}f(i)*g(i-j)\)

因为\(g(i)\)是个偶函数,因此有:

\(E_j=\sum_{i=1}^{j-1}f(i)*g(j-i)-\sum_{i=j+1}^{n}f(i)*g(i-j)\)

这时候,我们显然可以发现左边那个式子是个卷积,右边的这样一波化简就也变成了卷积形式:

卷积用FFT快速计算即可

时间复杂度\(O(nlogn)\)


Code

  1. //Luogu P3338 [ZJOI2014]力
  2. //Jan,18th,2019
  3. //FFT加速卷积
  4. #include<iostream>
  5. #include<cstdio>
  6. #include<cmath>
  7. #include<algorithm>
  8. #include<complex>
  9. using namespace std;
  10. typedef complex <double> cp;
  11. const double PI=acos(-1);
  12. const int M=100000+100;
  13. const int N=8*M;
  14. inline cp omega(int K,int n)
  15. {
  16. return cp(cos(2*PI*K/n),sin(2*PI*K/n));
  17. }
  18. void FFT(cp a[],int n,bool type)
  19. {
  20. static int len=0,num=n-1,t[N];
  21. while(num!=0) len++,num/=2;
  22. for(int i=0,j;i<=n;i++)
  23. {
  24. for(j=0,num=i;j<len;j++)
  25. t[j]=num%2,num/=2;
  26. reverse(t,t+len);
  27. for(j=0,num=0;j<len;j++)
  28. num+=t[j]*(1<<j);
  29. if(i<num) swap(a[i],a[num]);
  30. }
  31. for(int l=2;l<=n;l*=2)
  32. {
  33. int m=l/2;
  34. cp x0=omega(1,l);
  35. if(type==true) x0=conj(x0);
  36. for(int j=0;j<n;j+=l)
  37. {
  38. cp x=cp(1,0);
  39. for(int k=0;k<m;k++,x*=x0)
  40. {
  41. cp temp=x*a[j+k+m];
  42. a[j+k+m]=a[j+k]-temp;
  43. a[j+k]=a[j+k]+temp;
  44. }
  45. }
  46. }
  47. }
  48. int n,m;
  49. double q[N];
  50. cp f[N],g[N],f2[N];
  51. int main()
  52. {
  53. scanf("%d",&n);
  54. for(int i=1;i<=n;i++)
  55. scanf("%lf",&q[i]);
  56. for(int i=1;i<=n;i++)
  57. g[i]=(1.0/i/i);
  58. m=1;
  59. while(m<2*n) m*=2;
  60. for(int i=1;i<m;i++)
  61. f[i]=q[i],f2[i]=q[i];
  62. FFT(g,m,false);
  63. FFT(f,m,false);
  64. reverse(f2+1,f2+n+1);
  65. FFT(f2,m,false);
  66. for(int i=0;i<m;i++)
  67. f[i]*=g[i],f2[i]*=g[i];
  68. FFT(f,m,true);
  69. FFT(f2,m,true);
  70. for(int i=1;i<=n;i++)
  71. printf("%lf\n",(f[i].real()-f2[n-i+1].real())/m);
  72. return 0;
  73. }

[Luogu P3338] [ZJOI2014]力 (数论 FFT 卷积)的更多相关文章

  1. [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 ...

  2. 【BZOJ】3527: [Zjoi2014]力(fft+卷积)

    http://www.lydsy.com/JudgeOnline/problem.php?id=3527 好好的一道模板题,我自己被自己坑了好久.. 首先题目看错.......什么玩意.......首 ...

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

  4. luogu P3338 [ZJOI2014]力

    传送门 首先化简原式\[F_j=\sum_{i<j}\frac{q_iq_j}{(i-j)^2}-\sum_{i>j}\frac{q_iq_j}{(i-j)^2},E_j=F_j/q_j\ ...

  5. P3338 [ZJOI2014]力(FFT)

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

  6. [洛谷P3338] [ZJOI2014]力

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

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

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

  8. 【BZOJ 3527】 3527: [Zjoi2014]力 (FFT)

    3527: [Zjoi2014]力 Time Limit: 30 Sec  Memory Limit: 256 MBSec  Special JudgeSubmit: 2003  Solved: 11 ...

  9. P3338 [ZJOI2014]力 /// FFT 公式转化翻转

    题目大意: https://www.luogu.org/problemnew/show/P3338 题解 #include <bits/stdc++.h> #define N 300005 ...

随机推荐

  1. Maven环境搭建及常用命令、生命周期

    一.下载maven包,解压 二.配置环境变量,MAVEN_PATH=解压路径 添加到path中 三.测试  mvn -v 查看maven版本 四.设置本地仓库的路径 在conf文件夹下的setting ...

  2. Centos-当前登录用户信息- w who

    w who 显示当前登录系统的用户,但w显示的更为详细 who 相关参数 # 默认输出 用户名.登录终端.登录时间 -a 列出所有信息 -b    系统最近启动日期 -m   当前终端信息,相当于 w ...

  3. mapreduce的一些简单使用

    一.键值对RDD的创建 1.从文件中加载 /opt目录下创建wordky.txt文件. wordky.txt文件中输入以下三行字符: Hadoop is good Spark is fast Spar ...

  4. RTThread DFS文件系统使用: 基于使用SFUD驱动的SPI FLASH之上的ELM FATFS文件系统

    参考博文: 博文很长,但是实际要操作的步骤没几下. http://m.elecfans.com/article/730878.html  为了防止几年后文章链接找不到,我把文章复制过来了 /***** ...

  5. 手把手教你AspNetCore WebApi:入门

    需求 前几天,马老板给小明和小红一个"待办事项"网站,小明负责后端,小红负责前端,并要求网站可以同时在 Windows.和 Linux 上运行. 小明整理了一下"待办事项 ...

  6. 2. 在TCGA中找到并下载意向数据

    听说过别人用生信分析"空手套白狼"的故事吧想做吗好想学哦~ 或多或少都知道GEO和TCGA这些公共数据库吧!那么你知道怎么在数据库上找到意向数据,并且成功下载呢?这第一步要难倒一大 ...

  7. ansible-handlers变更执行操作

    1. ansible-handlers在变更执行操作  1) 编写playbook的handlers的配置文件 1 [root@test-1 bin]# vim /ansible/nginx/bin/ ...

  8. springCloud微服务调用失败【CannotGetJdbcConnectionException: Failed to obtain JDBC Connection】

    详情如下: 2019-07-28 10:56:18.229 ERROR 16212 --- [nio-8081-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet ...

  9. Nuxt+Vue聊天室|nuxt仿微信App界面|nuxt.js聊天实例

    一.项目简述 nuxt-chatroom 基于Nuxt.js+Vue.js+Vuex+Vant+VPopup等技术构建开发的仿微信|探探App界面社交聊天室项目.实现了卡片式翻牌滑动.消息发送/emo ...

  10. 题解:HDU 6598

    题解:HDU 6598 Description Now, Bob is playing an interesting game in which he is a general of a harmon ...