牛客练习赛2 A - Contest
链接:https://www.nowcoder.com/acm/contest/4/A
来源:牛客网
题目描述
输入描述:
第一行一个整数n,表示队伍数; 接下来n行,每行三个整数a[i], b[i], c[i],分别表示i在第一场、第二场和第三场比赛中的名次;n 最大不超过200000
输出描述:
输出一个整数表示满足条件的(x,y)数;64bit请用lld
输入例子:
4
1 3 1
2 2 4
4 1 2
3 4 3
输出例子:
5
-->
输入
4
1 3 1
2 2 4
4 1 2
3 4 3
输出
5
题解
三维偏序,$cdq$分治。
总的方案数有$n*(n - 1) / 2$种,不满足条件的就是三维偏序,减去即可。
#include<bits/stdc++.h>
using namespace std; const int maxn = 2e5 + 10;
struct X {
int a, b, c;
int id;
}s[maxn];
int n;
int f[maxn];
int c[maxn]; int lowbit(int x) {
return x & (-x);
} void update(int p, int v) {
for(int i = p; i < maxn; i = i + lowbit(i)) {
c[i] += v;
}
} int sum(int p) {
int res = 0;
while(p) {
res += c[p];
p -= lowbit(p);
}
return res;
} bool cmpA(const X& a, const X& b) {
return a.a < b.a;
} bool cmpB(const X& a, const X& b) {
return a.b < b.b;
} bool cmpID(const X& a, const X& b) {
return a.id < b.id;
} void cdq(int L, int R) {
if(L == R) return;
int mid = (L + R) / 2;
sort(s + L, s + mid + 1, cmpB);
sort(s + mid + 1, s + R + 1, cmpB);
int p1 = L;
for(int i = mid + 1; i <= R; i ++) {
while(p1 <= mid && s[p1].b <= s[i].b) {
update(s[p1].c, 1);
p1 ++;
}
f[s[i].id] += sum(s[i].c);
}
for(int i = L; i < p1; i ++) {
update(s[i].c, -1);
}
sort(s + L, s + mid + 1, cmpID);
sort(s + mid + 1, s + R + 1, cmpID);
cdq(L, mid);
cdq(mid + 1, R);
} int main() {
scanf("%d", &n);
for(int i = 1; i <= n; i ++) {
scanf("%d%d%d", &s[i].a, &s[i].b, &s[i].c);
}
sort(s + 1, s + 1 + n, cmpA);
for(int i = 1; i <= n; i ++) {
s[i].id = i;
// printf("%d %d %d %d\n", s[i].a, s[i].b, s[i].c, s[i].id);
}
cdq(1, n);
long long A = 1LL * n;
long long B = 1LL * (n - 1);
long long C = 0;
if(A % 2 == 0) A = A / 2;
else B = B / 2;
for(int i = 1; i <= n; i ++) {
C = C + 1LL * f[i];
}
printf("%lld\n", A * B - C); return 0;
}
牛客练习赛2 A - Contest的更多相关文章
- 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B
牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...
- 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A
牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...
- 最小生成树--牛客练习赛43-C
牛客练习赛43-C 链接: https://ac.nowcoder.com/acm/contest/548/C 来源:牛客网 题目描述 立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 ...
- 牛客练习赛51 **E-数列** (二分,贪心,构造)
牛客练习赛51 E-数列 链接:https://ac.nowcoder.com/acm/contest/1083/E来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 327 ...
- 牛客练习赛50 D tokitsukaze and Event (最短路,思维)
牛客练习赛50 D tokitsukaze and Event 链接:https://ac.nowcoder.com/acm/contest/1080/D来源:牛客网 时间限制:C/C++ 1秒,其他 ...
- 牛客练习赛48 C 小w的糖果 (数学,多项式,差分)
牛客练习赛48 C 小w的糖果 (数学,多项式) 链接:https://ac.nowcoder.com/acm/contest/923/C来源:牛客网 题目描述 小w和他的两位队友teito.toki ...
- 牛客练习赛48 A· 小w的a+b问题 (贪心,构造,二进制)
牛客练习赛48 A· 小w的a+b问题 链接:https://ac.nowcoder.com/acm/contest/923/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C ...
- 牛客练习赛42 C 出题的诀窍 (贡献,卡常)
牛客练习赛42 C 出题的诀窍 链接:https://ac.nowcoder.com/acm/contest/393/C来源:牛客网 题目描述 给定m个长为n的序列a1,a2,-,ama_1 , a_ ...
- 牛客练习赛53 D 德育分博弈政治课 (思维建图,最大流)
牛客练习赛53 D德育分博弈政治课 链接:https://ac.nowcoder.com/acm/contest/1114/D来源:牛客网 题目描述 德育分学长最近玩起了骰子.他玩的骰子不同,他的骰子 ...
随机推荐
- spring boot(三):spring data jpa的使用
@RequestMapping("/queryUserListByPageNativeQuery") public String queryUserListByPageNative ...
- [转载]8 种提升 ASP.NET Web API 性能的方法
http://www.oschina.net/translate/8-ways-improve-asp-net-web-api-performance 英文原文:8 ways to improve A ...
- 20145226夏艺华 《Java程序设计》第6周学习总结
教材学习内容总结 学习目标 理解流与IO 理解InputStream/OutPutStream的继承架构 理解Reader/Writer继承架构 会使用装饰类 会使用多线程进行并发程序设计 第十章 输 ...
- 微信小程序开发教程(七)逻辑层——.js详解
逻辑层,是事务逻辑处理的地方.对于小程序而言,逻辑层就是.js脚本文件的集合.逻辑层将数据进行处理后发送给视图层,同时接收视图层的事件反馈. 微信小程序开发框架的逻辑层是由JavaScript编写.在 ...
- hdu 1495 非常可乐 (广搜)
题目链接 Problem Description 大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为.因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶 ...
- [转]CNN 中千奇百怪的卷积方式大汇总
https://www.leiphone.com/news/201709/AzBc9Sg44fs57hyY.html 推荐另一篇很好的总结:变形卷积核.可分离卷积?卷积神经网络中十大拍案叫绝的操作. ...
- Shiro认证的另一种方式
今天在学习shiro的时候使用另一种shiro验证的方式. 总体的思路是: (1)先在自己的方法中进行身份的验证以及给出提示信息.(前提是将自己的验证方法设为匿名可访问) (2)当验证成功之后到Shi ...
- jQuery核心函数——(一)
- python的新特性
http://www.jb51.net/article/67699.htm Python中用format函数格式化字符串的用法:http://www.jb51.net/article/63672.ht ...
- 【HASPDOG】卸载
rpm -qa | grep aksusdb rpm -e aksusdb... rm -rf /var/hasplm