[Codechef November Challenge 2012] Arithmetic Progressions
题意:给定一个序列,求多少个三元组满足ai+ak=2*aj(i<j<k)。
题解:原来叉姐的讲义上有啊。。完全忘掉了。。
首先这个式子很明显是一个卷积。我们有了FFT的思路。但是肯定不能每一个数都去做一次。那怎么办呢?我们分块吧!(分块大法好)
对于每一个块我们统计出前面块的桶,同理我们也有后面块的桶,两个桶FFT一下我们就得到了以这个块内元素为j,i和k分别在前面的块与后面的块的方案了。然后我们还要解决两个在一个块,三个在一个块的问题。两个在一个块的我们直接去前后的桶里找,同一个块的直接n*n暴力。然后就做完啦!好妙啊!
这题被坑了好久。。因为空间莫名其妙的问题怎么都算不对(块开极端都可以,就是开中间不行),然后一个下午没有了。。
#include<bits/stdc++.h>
using namespace std;
#define LL long long
#define N 205005
#define INF 1e9
#define Bl 70
#define LIM 60000
const double PI=acos(-); inline LL read(){
LL x=,f=; char a=getchar();
while(a<'' || a>'') {if(a=='-') f=-; a=getchar();}
while(a>='' && a<='') x=x*+a-'',a=getchar();
return x*f;
} namespace FFT{
int rev[N]; struct vec{
double r,i;
vec operator * (const vec& w){return (vec){r*w.r-i*w.i,i*w.r+r*w.i};}
vec operator + (const vec& w){return (vec){r+w.r,i+w.i};}
vec operator - (const vec& w){return (vec){r-w.r,i-w.i};}
}A[N],B[N]; inline void fft(vec* x,int len,int f){
for(int i=;i<=len;i++) if(i<rev[i]) swap(x[i],x[rev[i]]);
for(int lnow=;lnow<=len;lnow<<=){
vec w,w0=(vec){cos(2.0*PI/lnow*f),sin(2.0*PI/lnow*f)},t1,t2;
for(int i=;i<len;i+=lnow){
w=(vec){,};
for(int j=i;j<i+lnow/;j++){
t1=x[j]; t2=w*x[j+lnow/];
x[j]=t1+t2; x[j+lnow/]=t1-t2;
w=w*w0;
}
}
}
} inline void work(int a[],int b[],int l1,int l2,LL s[]){
int len,t;
for(len=,t=;len<=(l1+l2+);len<<=,t++); t=<<(t-);
for(int i=;i<=len;i++) rev[i]=rev[i>>]>>|(i&?t:);
for(int i=;i<=len;i++) B[i]=A[i]=(vec){,};
for(int i=;i<=l1;i++) A[i].r=a[i];
for(int i=;i<=l2;i++) B[i].r=b[i];
fft(A,len,); fft(B,len,);
for(int i=;i<=len;i++) A[i]=A[i]*B[i];
fft(A,len,-);
for(int i=;i<=l1+l2;i++)
s[i]=(LL)(1.0*A[i].r/len+0.5);
} } int n,block_size,block_num;
int bel[N],l[Bl+],r[Bl+],a[N];
LL tot,ans[*LIM+];
int lsum[LIM+],rsum[LIM+],cnt[*LIM+]; inline void brutal_force(int x){
for(int i=l[x];i<=r[x];i++) rsum[a[i]]--;
memset(ans,,sizeof(ans));
FFT::work(lsum,rsum,,,ans);
for(int i=l[x];i<=r[x];i++){
tot+=ans[*a[i]];
for(int j=l[x];j<i;j++)
if(*a[i]-a[j]>) tot+=rsum[*a[i]-a[j]];
for(int j=i+;j<=r[x];j++)
if(*a[i]-a[j]>) tot+=lsum[*a[i]-a[j]];
}
for(int i=l[x];i<=r[x];i++) lsum[a[i]]++;
memset(cnt,,sizeof(cnt));
for(int i=l[x];i<=r[x];i++){
tot+=cnt[a[i]];
for(int j=l[x];j<i;j++)
if(*a[i]-a[j]>) cnt[*a[i]-a[j]]++;
}
} int main(){
n=read(); block_size=;
block_num=(n-)/block_size+;
for(int i=;i<=n;i++) a[i]=read(),bel[i]=(i-)/block_size+;
for(int i=;i<=block_num;i++) l[i]=(i-)*block_size+,r[i]=min(n,i*block_size);
for(int i=;i<=n;i++) rsum[a[i]]++;
for(int i=;i<=block_num;i++) brutal_force(i);
printf("%lld\n",tot);
return ;
}
[Codechef November Challenge 2012] Arithmetic Progressions的更多相关文章
- 【分块+树状数组】codechef November Challenge 2014 .Chef and Churu
https://www.codechef.com/problems/FNCS [题意] [思路] 把n个函数分成√n块,预处理出每块中各个点(n个)被块中函数(√n个)覆盖的次数 查询时求前缀和,对于 ...
- CodeChef November Challenge 2013 部分题解
http://www.codechef.com/NOV13 还在比...我先放一部分题解吧... Uncle Johny 排序一遍 struct node{ int val; int pos; }a[ ...
- Codechef November Challenge 2019 Division 1
Preface 这场CC好难的说,后面的都不会做QAQ 还因为不会三进制位运算卷积被曲明姐姐欺负了,我真是太菜了QAQ PS:最后还是狗上了六星的说,期待两(三)场之内可以上七星 Physical E ...
- CodeChef November Challenge 2014
重点回忆下我觉得比较有意义的题目吧.水题就只贴代码了. Distinct Characters Subsequence 水. 代码: #include <cstdio> #include ...
- CodeChef November Challenge 2019 Division 1题解
传送门 AFO前的最后一场CC了--好好打吧-- \(SIMGAM\) 偶数行的必定两人平分,所以只要抢奇数行中间那个就行了 这题怎么被爆破了 //quming #include<bits/st ...
- [Educational Codeforces Round 16]D. Two Arithmetic Progressions
[Educational Codeforces Round 16]D. Two Arithmetic Progressions 试题描述 You are given two arithmetic pr ...
- Dirichlet's Theorem on Arithmetic Progressions 分类: POJ 2015-06-12 21:07 7人阅读 评论(0) 收藏
Dirichlet's Theorem on Arithmetic Progressions Time Limit: 1000MS Memory Limit: 65536K Total Submi ...
- 洛谷P1214 [USACO1.4]等差数列 Arithmetic Progressions
P1214 [USACO1.4]等差数列 Arithmetic Progressions• o 156通过o 463提交• 题目提供者该用户不存在• 标签USACO• 难度普及+/提高 提交 讨论 题 ...
- Codechef April Challenge 2019 游记
Codechef April Challenge 2019 游记 Subtree Removal 题目大意: 一棵\(n(n\le10^5)\)个结点的有根树,每个结点有一个权值\(w_i(|w_i\ ...
随机推荐
- 将场景导出XML或JSON或二进制而且解析还原场景
导出unity场景的全部游戏对象信息,一种是XML一种是JSON. 本篇文章我们把游戏场景中游戏对象的.旋转.缩放.平移与Prefab的名称导出在XML与JSON中.然后解析刚刚导出的XML或JSON ...
- Farm Tour(最小费用最大流模板)
Farm Tour Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 18150 Accepted: 7023 Descri ...
- Java中Solr集群的测试
import org.apache.solr.client.solrj.impl.CloudSolrServer; import org.apache.solr.common.SolrInputDoc ...
- RTLabel 富文本
本节关于RTLable基本介绍,原文来自 https://github.com/honcheng/RTLabel RTLabel 基于富文本的格式,适用于iOS,类似HTML的标记. RTLabel ...
- PL/SQL 入门
1. 概述 PL/SQL(Procedure Language/SQL)是 Oracle 对 sql 语言的过程化扩展,指在 SQL 命令语言中增加了 过程处理语句(如分支,循环等),使 SQL 语言 ...
- Java基础—运算符(转载)
转载自:Java运算符 计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,Java也提供了一套丰富的运算符来操纵变量.我们可以把运算符分成以下几组: 算术运算符 关系运算符 位运算符 逻辑运 ...
- SSH远程登陆docker容器
环境: Ubuntu 16.04(mac osx的VMware Fushion环境) 任务: Ubuntu 16.04通过SSH登陆docker(目的是为了运行在其他服务器的Jenkins访问dock ...
- IT basic knowledge
LAMP: Linux Apache MySQL PHP URL & URI: 统一资源定位符是统一资源标志符的一个下种.统一资源标志符确定一个资源,而统一资源定位符不但确定一个资源, 而且还 ...
- MySQL数据库(4)_MySQL数据库外键约束、表查询
一.外键约束 创建外键 --- 每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任 ----主表 CREATE TABLE ClassCharger( id TINYINT PRIMARY ...
- Redis慢查询,redis-cli,redis-benchmark,info
一.慢查询: 1.慢查询的作用:通过慢查询分析,找到有问题的命令进行优化. 2.慢查询的redis的配置参数: slowlog-log-slower-than 慢查询预设阈值(单位是微秒1秒=1000 ...