[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}\frac{q_i q_j}{(i-j)^2 }\)
令\(E_i=F_i/q_i\),求\(E_i\).
输入输出格式
输入格式:
第一行一个整数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]
题解
一道对于刚学FFT的人不错的题目。
完全可以自己手推。
搞了我晚自习半个小时才推出来...作业都没写完。
对于这个式子
\(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
所以我们首先消掉qi
所以变成了这样
\(E_j = \sum_{i<j}\frac{q_i}{(i-j)^2 }-\sum_{i>j}\frac{q_i}{(i-j)^2 }\)
好,接下来我们发现暴力O(n^2)就可以求出来了。
怎么转换到FFT里面去?
先O(n)处理出(i-j)^2.
这个时候我们列出样例。
对于E1=
4006373.885184*(1-1)^2 +
15375036.435759*(1-2)^2 -
1717456.469144*(1-3)^2 -
8514941.004912*(1-4)^2 -
1410681.345880*(1-5)^2 -
然后加起来
对于E2=
4006373.885184*(2-1)^2 +
15375036.435759*(2-2)^2 +
1717456.469144*(2-3)^2 -
8514941.004912*(2-4)^2 -
1410681.345880*(2-5)^2 -
观察后面的(i-j)^2项。
是不是相当于
\(-0.0625,-0.111111x,-0.25x^2,-1x^3,0x^4,1x^5,0.25x^6,0.111111x^7,0.0625x^8\)
\(*\)
\(4006373.885184,15375036.435759x,1717456.469144x^2,8514941.004912x^3,1410681.345880x^4\)
转换为卷积就可以了。
Code
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<iostream>
#include<cstring>
#include<complex>
#define debug cout<<"JEFF是我们的红太阳!!"<<endl;
#define ll long long
using namespace std;
typedef complex<double> cp;
const int N=1e6+5;
const double pi=acos(-1.0);
cp a[N],b[N];
ll l,n,cnt,limit=1,r[N];
int read(){
    int x=0,w=1;char ch=getchar();
    while(ch>'9'||ch<'0'){if(ch=='-')w=-1;ch=getchar();}
    while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
    return x*w;
}
void FFT(cp *A,int type){
    for(int i=0;i<limit;i++)if(i<r[i])swap(A[r[i]],A[i]);
    for(int i=1;i<limit;i<<=1){
        cp wn(cos(pi/i),sin(type*pi/i));
        for(int j=0;j<limit;j+=(i<<1)){
            cp w(1,0),x,y;
            for(int k=0;k<i;k++){
                x=A[k+j];y=A[k+j+i]*w;
                A[k+j]=x+y;A[k+j+i]=x-y;
                w=w*wn;
            }
        }
    }
}
int main(){
    n=read();
    for(int i=0;i<n;i++){
        double x;
        scanf("%lf",&x);
        b[i]=x;
    }
    for(int i=n-1;i>=1;i--){
        a[cnt]=-(1.0/(1.0*i*i));cnt++;
    }a[cnt]=0;cnt++;
    for(int i=1;i<=n-1;i++){
        a[cnt]=(1.0/(1.0*i*i));cnt++;
    }cnt--;
    while(cnt+n>=limit)limit<<=1,l++;
    for(int i=1;i<limit;i++)r[i]=(r[i>>1]>>1)|((i&1)<<(l-1));
    FFT(a,1);FFT(b,1);
    for(int i=0;i<limit;i++)a[i]*=b[i];
    FFT(a,-1);for(int i=0;i<limit;i++)a[i]/=limit;
    for(int i=n-1;i<=2*n-2;i++)printf("%.3lf\n",(double)(a[i].real()));
    return 0;
}
[Luogu]P3338 [ZJOI2014]力(FFT)的更多相关文章
- [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 公式转化翻转
		题目大意: https://www.luogu.org/problemnew/show/P3338 题解 #include <bits/stdc++.h> #define N 300005 ... 
- 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\ ... 
- 洛谷 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}$ ... 
随机推荐
- 按时间划分备份MySQL脚本
			按时间划分备份MySQL脚本 #!/bin/bash BASE_PATH=/data/dump/ JIRA_FILE_NAME=ZY798-`date +%Y%m%d%H%M%S`; cd /usr/ ... 
- 《Let's Build A Simple Interpreter》之 Golang 版
			一直以来对编译器/解释器等都较有兴趣.我非科班出身,当初还在大学时,只是马马虎虎看完了<编译原理>之类教材,上机非常少,对龙书之类圣经也只是浅尝辄止而已.工作至今,基本已将编译原理相关知识 ... 
- 清空chrome浏览器缓存
			缓存是一个很深奥的东西,虽然查了半天,还是没有搞清楚,希望以后可以遇到前端大神,可以给一个傻瓜化的通俗易懂的解释 已经上线的,后续有迭代的软件,迭代的版本不应该手动清除缓存了,因为太麻烦,对客户来说不 ... 
- .Net调用Java编写的WebServices返回值为Null的解决方法(SoapUI工具测试有返回值)
			最近在项目中与别的公司对接业务,对方是Java语言,需要调用对方的WebServices,结果常规的添加web引用的方法可以传过去值,但是返回值为null 查了很多资料,没有解决方法 思考应该是.Ne ... 
- Android 混淆后的代码调试
			ProGuard的输出文件及用处 混淆之后,会给我们输出一些文件,在gradle方式下是在<project_dir>/build/proguard/目录下,ant是在<project ... 
- leetcode笔记:Find Median from Data Stream
			一. 题目描写叙述 Median is the middle value in an ordered integer list. If the size of the list is even, th ... 
- ORA-38760: This database instance failed to turn on flashback database
			ORA-38760: This database instance failed to turn on flashback database 问题背景: 測试数据库运行shutdown ... 
- PHP第八课 字符串拆分经常使用函数
			课程概要: 通过这节课可以对字符串进行主要的操作. 字符串知识点: 1.字符串的处理介绍 2.经常使用的字符串输出函数 3.经常使用的字符串格式化函数 4.字符串比較函数 5.正則表達式在字符串中的应 ... 
- POJ 2318 叉积判断点与直线位置
			TOYS Description Calculate the number of toys that land in each bin of a partitioned toy box. Mom ... 
- asp.net mvc5 文件下载上传
			下载:是通过点击a标签直接下载的方式,没有其他任何要求,在服务器上存在实体文件,不需要请求后台控制层 前段js: <a id="NF-DownLoad" authorize= ... 
