Hdu5517 Triple
Description
Given the finite multi-set \(A\) of \(n\) pairs of integers, an another finite multi-set \(B\) of \(m\) triples of integers, we define the product of \(A\) and \(B\) as a multi-set
\[C=A∗B=\lbrace \langle a,c,d \rangle \mid \langle a,b \rangle \in A, \langle c,d,e \rangle \in B \; and \; b=e \rbrace
\]For each ⟨a,b,c⟩∈C, its BETTER set is defined as
\[BETTER_{C}(\langle a,b,c \rangle )=\lbrace \langle u,v,w \rangle \in C \mid \langle u,v,w \rangle \neq \langle a,b,c \rangle, u \ge a, v \ge b, w \ge c \rbrace
\]As a multi-set of triples, we define the TOP subset (as a multi-set as well) of \(C\), denoted by \(TOP(C)\), as
\[TOP(C)=\lbrace \langle a,b,c \rangle \in C \mid BETTER_{C}(\langle a,b,c \rangle \rbrace ) = \phi
\]You need to compute the size of \(TOP(C)\).
Input
The input contains several test cases. The first line of the input is a single integer \(t (1 \le t \le 10)\) which is the number of test case. Then \(t\) test cases follow.
Each test case contains three lines. The first line contains two integers \(n (1 \le n \le 10^{5})\) and \(m (1 \le m \le 10^{5})\) corresponding to the size of \(A\) and \(B\) respectively.
The second line contains \(2 \times n\) nonnegative integers \(a_{1},b_{1},a_{2},b_{2},\cdots,a_{n},b_{n}\) which describe the multi-set \(A\), where \(1 \le a_{i},b_{i} \le 10^{5}\).
The third line contains \(3 \times m\) nonnegative integers \(c_{1},d_{1},e_{1},c_{2},d_{2},e_{3},\cdots,c_{m},d_{m},e_{m}\) corresponding to the \(m\) triples of integers in \(B\), where \(1 \le c_{i},d_{i} \le 10^{3}\) and \(1 \le e_{i} \le 10^{5}\).
Output
For each test case, you should output the size of set \(TOP(C)\).
Sample Input
2
5 9
1 1 2 2 3 3 3 3 4 2
1 4 1 2 2 1 4 1 1 1 3 2 3 2 2 4 1 2 2 4 3 3 2 3 4 1 3
3 4
2 7 2 7 2 7
1 4 7 2 3 7 3 2 7 4 1 7
Sample Output
Case #1: 5
Case #2: 12
首先对于二元组\(\langle a_{1},b \rangle,\langle a_{2},b \rangle \dots\)我肯定直选\(a\)最大的与\(B\)集合中的元素配对。不妨设最大的为\(a_{1}\),若我选择了\(a_{i}\)配对,那么$$\langle a_{1},c,d \rangle \in BETTER_{C}\langle a_{i},b,c \rangle$$
所以\(C\)中有用的元素减少到了\(O(N)\)个。之后就是要找的极大的三元组的个数,这个CDQ分治或者二维树状数组都行(就是最大非升子序列长度为\(1\)的元素个数)。
#include<iostream>
#include<vector>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<cstdlib>
using namespace std;
typedef long long ll;
#define lowbit(a) (a&(-a))
#define maxm (1010)
#define maxn (100010)
int T,tot,cnt,N,M,A[maxn],nA[maxn],tree[maxm][maxm]; ll ans;
struct node { int a,b; }; vector <node> B[maxn];
struct mode
{
int a,b,c; ll num;
friend inline bool operator <(const mode &x,const mode &y)
{
if (x.a != y.a) return x.a < y.a;
else
{
if (x.b != y.b) return x.b < y.b;
else return x.c < y.c;
}
}
friend inline bool operator ==(const mode &x,const mode &y) { return x.a == y.a&&x.b == y.b&&x.c == y.c; }
}C[maxn],bac[maxn];
inline bool cmp(int x,int y) { return x > y; }
inline void ins(int i,int y)
{
for (;i <= 1000;i += lowbit(i))
for (int j = y;j <= 1000;j += lowbit(j)) ++tree[i][j];
}
inline int calc(int i,int y)
{
int ret = 0;
for (;i;i -= lowbit(i)) for (int j = y;j;j -= lowbit(j)) ret += tree[i][j];
return ret;
}
inline void init()
{
tot = cnt = ans = 0; memset(tree,0,sizeof(tree));
for (int i = 1;i <= 100000;++i) A[i] = nA[i] = 0,B[i].clear();
}
int main()
{
freopen("5517.in","r",stdin);
freopen("5517.out","w",stdout);
scanf("%d",&T);
for (int Cas = 1;Cas <= T;++Cas)
{
printf("Case #%d: ",Cas);
scanf("%d %d",&N,&M); init();
for (int i = 1;i <= N;++i)
{
int a,b; scanf("%d %d",&a,&b);
if (a > A[b]) A[b] = a,nA[b] = 1;
else if (a == A[b]) nA[b]++;
}
for (int i = 1;i <= M;++i)
{
int a,b,c; scanf("%d %d %d",&a,&b,&c);
B[c].push_back((node){a,b});
}
for (int i = 1;i <= 100000;++i)
if (A[i]&&!B[i].empty())
for (int j = 0,nn = B[i].size();j < nn;++j)
bac[++tot] = (mode){A[i],B[i][j].a,B[i][j].b,nA[i]};
sort(bac+1,bac+tot+1);
for (int i = 1,j;i <= tot;i = j)
{
for (j = i+1;j <= tot&&bac[j] == bac[i];++j) bac[i].num += bac[j].num;
C[++cnt] = bac[i];
}
for (int i = cnt;i;--i)
{
int p1 = 1000-C[i].b+1,p2 = 1000-C[i].c+1;
if (!calc(p1,p2)) ans += C[i].num; ins(p1,p2);
}
cout << ans << endl;
}
fclose(stdin); fclose(stdout);
return 0;
}
Hdu5517 Triple的更多相关文章
- 【hdu5517】Triple
题目大意:给定一个二元组集合A{<a, b>}, 一个三元组集合B{<c, d, e>}, 定义 C 为 A 和 B 在 {b = e} 上的连接,求 C 集合中凸点的个数,即 ...
- 山东省第七届ACM省赛------Triple Nim
Triple Nim Time Limit: 2000MS Memory limit: 65536K 题目描述 Alice and Bob are always playing all kinds o ...
- hdu 3908 Triple(组合计数、容斥原理)
Triple Time Limit: 5000/3000 MS (Java/Others) Memory Limit: 125536/65536 K (Java/Others) Total Su ...
- hdu 5517 Triple(二维树状数组)
Triple Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Sub ...
- Codeforces 1071 C - Triple Flips
C - Triple Flips 思路: 小范围暴力 大范围递归构造 构造方法: solve(l, r) 表示使l 到 r 区间全变为0的方法 为了使反转次数小于等于n/3 + 12 我们只需要保证每 ...
- 【BZOJ3771】Triple(生成函数,多项式运算)
[BZOJ3771]Triple(生成函数,多项式运算) 题面 有\(n\)个价值\(w\)不同的物品 可以任意选择\(1,2,3\)个组合在一起 输出能够组成的所有价值以及方案数. \(n,w< ...
- PAT 1009. Triple Inversions (35) 数状数组
Given a list of N integers A1, A2, A3,...AN, there's a famous problem to count the number of inversi ...
- 【BZOJ 3771】 3771: Triple (FFT+容斥)
3771: Triple Time Limit: 20 Sec Memory Limit: 64 MBSubmit: 547 Solved: 307 Description 我们讲一个悲伤的故事. ...
- hihoCoder #1872 : Pythagorean triple
此题是 2018 年 ICPC Asia Beijing Regional Contest 的 C 题. 题目大意 求斜边长度不超过 $n$($ n \le 10^9$) 的勾股数的数量.不计两直角边 ...
随机推荐
- Linux下jvm、tomcat、mysql、log4j优化配置笔记[转]
小菜一直对操作系统心存畏惧,以前也很少接触,这次创业购买了Linux云主机,由于木有人帮忙,只能自己动手优化服务器了.... 小菜的云主机配置大致为:centeos6(32位),4核心cpu,4G内存 ...
- Upstart概述引导方法事件驱动的任务和服务
/********************************************************************* * Author : Samson * Date ...
- 谷歌google搜索打不开、谷歌gmail邮箱及相关服务无法登录的解决的方法
歌打不开 google打不开,与中国大陆封杀有关,可是主要是由于近期googleserver在全球范围内又一次进行了布局调整. 解决的方法是仅仅要改动用户本地计算机hosts文件就能够了. 一.Win ...
- 网络学习笔记----02--IGMP组播、ARP
IGMP组播 :在路由器的接口上运行,周期性扫描本网段是否有绑定某个多播地址的计算机. ARP,全称Address Resolution Protoco,将广播中的IP地址解析成MAC地址 查看MAC ...
- Boost Build
Window XP + Visual Studio 2008 获取Boost库源码 我们可以从http://www.boost.org/ 上获取boost的源代码.当前最新版本为1.45.0. 解压到 ...
- android注解使用详解(图文)
在使用Java的SSH框架的时候,一直在感叹注解真是方便啊,关于注解的原理,大家可以参考我的另一片文章Java注解详解.最近有时间研究了android注解的使用,今天与大家分享一下. android中 ...
- System Operations on AWS - Lab 2 - Configuring VPC
建立包含Public和Private子网的VPC,建立Internet Gateway,建立Public和Private子网的路由表,创建NAT和Bastion EC2实例 1. 配置你的私有虚拟云 ...
- XML的基本操作
所有 XML 文档中的文本均会被解析器解析.只有 CDATA 区段(CDATA section)中的文本会被解析器忽略.CDATA 部分中的所有内容都会被解析器忽略.CDATA 部分由 "& ...
- Centos6.5 安装 MariaDB-10.0.20-linux-x86_64.tar.gz
下载mariadb :https://downloads.mariadb.org/ 我选择mariadb-10.0.20-linux-x86_64.tar.gz这个版本 复制安装文件 /opt 目录 ...
- 真机调试报错:Could not find Developer Disk Image 或 Could not locate device support files.
废话不多说,原因是用的Xcode版本所支持的最高iOS系统低于真机iOS系统导致. 解决方案: 1.升级到最新的Xcode版本 2.不想升级Xcode,那就找已经把Xcode升级到最新版本的朋友,发给 ...