The Preliminary Contest for ICPC Asia Shanghai 2019 C. Triple
FFT第三题!
其实就是要求有多少三元组满足两短边之和大于等于第三边。
考虑容斥,就是枚举最长边,另外两个数组里有多少对边之和比它小,然后就是 $n^3$ 减去这个答案。
当 $n \leq 1000$ 时,直接暴力,因为如果继续 FFT 的话复杂度是 $O(slogs)$,$s$ 表示值域,值域都到 $10^5$,$100$ 组吃不消。
比 $1000$ 大就 FFT 做即可。
#include <bits/stdc++.h>
struct Complex {
double r, i;
void clear() { r = i = 0.0; }
Complex(double r = , double i = ): r(r), i(i) {}
Complex operator + (const Complex &p) const { return Complex(r + p.r, i + p.i); }
Complex operator - (const Complex &p) const { return Complex(r - p.r, i - p.i); }
Complex operator * (const Complex &p) const { return Complex(r * p.r - i * p.i, r * p.i + i * p.r); }
};
const double pi = acos(-1.0);
const int N = 5e5 + ;
int n, limit, l, r[N];
void FFT(Complex *a, int n, int pd) {
for (int i = ; i < n; i++)
if (i < r[i])
std::swap(a[i], a[r[i]]);
for (int mid = ; mid < n; mid <<= ) {
Complex wn(cos(pi / mid), pd * sin(pi / mid));
for (int l = mid << , j = ; j < n; j += l) {
Complex w(1.0, 0.0);
for (int k = ; k < mid; k++, w = w * wn) {
Complex u = a[k + j], v = w * a[k + j + mid];
a[k + j] = u + v;
a[k + j + mid] = u - v;
}
}
}
if (pd < )
for (int i = ; i < n; i++)
a[i] = Complex(a[i].r / n, a[i].i / n);
}
#define ll long long
int A[N], B[N], C[N];
ll cntA[N], cntB[N], cntC[N];
void init(int val) {
for (int i = ; i <= val; i++)
cntA[i] = cntB[i] = cntC[i] = ;
}
void solve1() {
int val = * std::max(A[n], std::max(B[n], C[n])) + ;
for (int i = ; i <= val; i++)
cntA[i] += cntA[i - ], cntB[i] += cntB[i - ], cntC[i] += cntC[i - ];
ll ans = ;
for (int i = ; i <= n; i++)
for (int j = ; j <= n; j++) {
int cur = A[i] + B[j];
ans += cntC[val] - cntC[cur];
cur = A[i] + C[j];
ans += cntB[val] - cntB[cur];
cur = B[i] + C[j];
ans += cntA[val] - cntA[cur];
}
ans = 1LL * n * n * n - ans;
assert(ans >= );
printf("%lld\n", ans);
}
Complex a[N], b[N], c[N], res[N];
void solve2() {
limit = , l = ;
int val = * std::max(A[n], std::max(B[n], C[n])) + ;
while (limit <= val) limit <<= , l++;
for (int i = ; i < limit; i++)
r[i] = r[i >> ] >> | ((i & ) << (l - ));
for (int i = ; i < limit; i++)
a[i] = Complex((double)cntA[i], 0.0), b[i] = Complex((double)cntB[i], 0.0), c[i] = Complex((double)cntC[i], 0.0);
for (int i = ; i <= val; i++)
cntA[i] += cntA[i - ], cntB[i] += cntB[i - ], cntC[i] += cntC[i - ];
FFT(a, limit, ); FFT(b, limit, ); FFT(c, limit, );
for (int i = ; i < limit; i++)
res[i] = a[i] * b[i];
FFT(res, limit, -);
ll ans = ;
for (int i = ; i < limit; i++) {
ll temp = (ll)(res[i].r + 0.5);
ans += (cntC[val] - cntC[i]) * temp;
}
for (int i = ; i < limit; i++)
res[i] = b[i] * c[i];
FFT(res, limit, -);
for (int i = ; i < limit; i++) {
ll temp = (ll)(res[i].r + 0.5);
ans += (cntA[val] - cntA[i]) * temp;
}
for (int i = ; i < limit; i++)
res[i] = a[i] * c[i];
FFT(res, limit, -);
for (int i = ; i < limit; i++) {
ll temp = (ll)(res[i].r + 0.5);
ans += (cntB[val] - cntB[i]) * temp;
}
ans = 1LL * n * n * n - ans;
assert(ans >= );
printf("%lld\n", ans);
}
int main() {
int T;
scanf("%d", &T);
for (int kase = ; kase <= T; kase++) {
scanf("%d", &n);
int x = ;
for (int i = ; i <= n; i++)
scanf("%d", A + i), x = std::max(x, A[i]);
for (int i = ; i <= n; i++)
scanf("%d", B + i), x = std::max(x, B[i]);
for (int i = ; i <= n; i++)
scanf("%d", C + i), x = std::max(x, C[i]);
init(N - );
std::sort(A + , A + + n);
std::sort(B + , B + + n);
std::sort(C + , C + + n);
for (int i = ; i <= n; i++)
cntA[A[i]]++, cntB[B[i]]++, cntC[C[i]]++;
printf("Case #%d: ", kase);
if (n <= ) solve1();
else solve2();
}
return ;
}
The Preliminary Contest for ICPC Asia Shanghai 2019 C. Triple的更多相关文章
- The Preliminary Contest for ICPC Asia Shanghai 2019 C Triple(FFT+暴力)
The Preliminary Contest for ICPC Asia Shanghai 2019 C Triple(FFT+暴力) 传送门:https://nanti.jisuanke.com/ ...
- The Preliminary Contest for ICPC Asia Shanghai 2019
传送门 B. Light bulbs 题意: 起初\(n\)个位置状态为\(0\),\(m\)次操作,每次操作更换区间状态:\(0\)到\(1\),\(1\)到\(0\). 共有\(T,T\leq 1 ...
- 01背包方案数(变种题)Stone game--The Preliminary Contest for ICPC Asia Shanghai 2019
题意:https://nanti.jisuanke.com/t/41420 给你n个石子的重量,要求满足(Sum<=2*sum<=Sum+min)的方案数,min是你手里的最小值. 思路: ...
- 给定进制下1-n每一位数的共享(Digit sum)The Preliminary Contest for ICPC Asia Shanghai 2019
题意:https://nanti.jisuanke.com/t/41422 对每一位进行找循环节规律就行了. #define IOS ios_base::sync_with_stdio(0); cin ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 A. Lightning Routing I
传送门 因为某些原因,所以我就去学了 $LCT$ 维护直径, $LCT$ 维护直径我上一个博客讲得很详细了:传送门 这里维护虚儿子用的是 $multiset$ ,没写可删堆 #include<i ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 L. Digit sum
题目:https://nanti.jisuanke.com/t/41422 思路:预处理 #include<bits/stdc++.h> using namespace std; ][]= ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 J. Stone game
题目:https://nanti.jisuanke.com/t/41420 思路:当a(a∈S′)为最小值 如果Sum(S′)−a≤Sum(S−S′)成立 那么(∀t∈S′,Sum(S′)−t≤Sum ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 D. Counting Sequences I
题目:https://nanti.jisuanke.com/t/41412思路:dfs 先取ai>2 2^12>3000 因此至多取11个 其余用1补 ...
- The Preliminary Contest for ICPC Asia Shanghai 2019 B. Light bulbs
题目:https://nanti.jisuanke.com/t/41399 思路:差分数组 区间内操作次数为奇数次则灯为打开状态 #include<bits/stdc++.h> using ...
随机推荐
- Unity Glossary
https://docs.unity3d.com/2018.4/Documentation/Manual/Glossary.html 2D terms 2D Physics terms AI term ...
- ksync
#include <linux/init.h> #include <linux/module.h> #include <linux/types.h> #includ ...
- tsar使用说明
常用命令 tsar --nginx --live -i 1 查询1秒的状态每秒采样一次 系统模块 cpu 字段含义 user: 表示CPU执行用户进程的时间,通常期望用户空间CPU越高越好. ...
- pixijs shader教程
pixijs 写shader 底层都封装好了 只要改改片段着色器就行了 pxijs一定刚要设置支持透明 不然 颜色不支持透明度了 const app = new PIXI.Application({ ...
- app版本升级的测试点
移动端版本更新升级是一个比较重要的功能点,主要分为强制更新和非强制更新. 1.强制更新需要测试的点有: 1)强制升级是否可以升级成功 从老版本的包升级到新版版的包是否可以升级成功. 2)升级后的数据是 ...
- Mac终端常用快捷键
Ctrl + a 跳到行首Ctrl + e 跳到行尾Ctrl + d 删除一个字符,相当于通常的Delete键(命令行若无所有字符,则相当于exit:处理多行标准输入时也表示eof)Ctrl + h ...
- jquery实现移动端页面加载后,向上滚动指定距离无效引起的探索
效果如下,页面加载完后向上滚动一段距离 最近一同事询问用jquery为何无法实现上面效果,查看代码后发现代码并没写错, 也正确引入了zepto.js,也不是版本问题(因为是移动端项目,出于性能和需 ...
- IL 语法分析
Managed Heap: GC auto manage. One process, One heap. Call Stack: Runtime auto manage, every time whe ...
- webstorm关闭烦人的eslint语法检查
使用了eslint语法检查之后发现JS代码里面处处是红线,通过右键菜单中的fix eslint problems选项又会发现页面代码的格式被eslint换行得不分青红皂白,索性关闭exlint语法检查 ...
- Kubernetes 有状态与无状态介绍
Kubernetes 有状态与无状态介绍 无状态:deployment - 认为所有pod都是一样的,不具备与其他实例有不同的关系. - 没有顺序的要求. - 不用考虑再哪个Node运行. - 随意扩 ...