soj98 卡牌
题意:一共有n张牌,每张牌有三个属性ai,bi,ci。问在属性上限为A,B,C的所有牌中有多少张牌满足至少有两个属性可以完全压制(严格大于)那n张牌?
n<=50W。
标程:
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
typedef long long ll;
int read()
{
int x=,f=;char ch=getchar();
while (ch<''||ch>'') {if (ch=='-') f=-;ch=getchar();}
while (ch>=''&&ch<='') x=(x<<)+(x<<)+ch-'',ch=getchar();
return x*f;
}
const int N=;
int n,A,B,C,Mx_a[N],Mx_b[N],ma,mb;
ll ans,sum_a[N],sum_b[N];
struct node{int a,b,c;}p[N];
bool operator < (const node &A,const node &B){return A.c>B.c;}
int main()
{
n=read();A=read();B=read();C=read();
for (int i=;i<=n;i++) p[i].a=read(),p[i].b=read(),p[i].c=read();
sort(p+,p+n+);
for (int i=;i<=n;i++) Mx_b[p[i].a]=max(Mx_b[p[i].a],p[i].b);
for (int i=;i<=n;i++) Mx_a[p[i].b]=max(Mx_a[p[i].b],p[i].a);
for (int i=B-;i>=;i--) Mx_a[i]=max(Mx_a[i+],Mx_a[i]);
for (int i=A-;i>=;i--) Mx_b[i]=max(Mx_b[i+],Mx_b[i]);
for (int i=;i<=A;i++) sum_a[i]=sum_a[i-]+B-Mx_b[i];
for (int i=;i<=B;i++) sum_b[i]=sum_b[i-]+A-Mx_a[i];
for (int i=C,head=;i>=;i--)
{
while (head<=n&&p[head].c==i) ma=max(ma,p[head].a),mb=max(mb,p[head].b),head++;
if (Mx_b[ma+]<mb+) ans+=(ll)(A-ma)*(B-mb);
else ans+=sum_a[A]-sum_a[ma]-sum_b[mb];
}
printf("%lld\n",ans);
return ;
}
易错点:注意前缀和统计时的循环下标勿混。
题解:前缀和+数形结合
考场上我写了个n^2,在数据随机时nlogn居然跑过去了。。。
n^2暴力:按照ci从大到小排序,枚举选取的C,那么对于ci<C的点,只要ai,bi其一被压制即可。对于ci>=C的点,两个都得被压制,维护一个A,B取值的max转移即可,并且单调。再按照B进行排序,用类似的方法可以计算出A的取值范围。
正解:同样按照C从大到小排序,对于ci>=C的max限制也一样。而对于ci<C的点,我们将关于A,B的函数图像画出来,发现是一个阶梯形的结构。Mx_a[i]表示i取i~B时ai的最大值,Mx_b[i]同理。如果不考虑前面的max限制,答案就是A*B-下阶梯的面积。
如果有限制,就相当于是一条竖线一条横线即一个矩形的限制。如果矩形和阶梯有交,那么取外阶梯的面积-前段排除面积-后段排除面积即可。用前缀和预处理。反之,就是直接取一个矩形的面积。时间复杂度O(nlogn)->排序。
soj98 卡牌的更多相关文章
- BZOJ 4205: 卡牌配对
4205: 卡牌配对 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 173 Solved: 76[Submit][Status][Discuss] ...
- 使用UIKit制作卡牌游戏(三)ios游戏篇
译者: Lao Jiang | 原文作者: Matthijs Hollemans写于2012/07/13 转自朋友Tommy 的翻译,自己只翻译了这第三篇教程. 原文地址: http://www.ra ...
- CCOrbitCamera卡牌翻转效果
static CCOrbitCamera* create(float t, float radius, float deltaRadius, float angleZ, float deltaAngl ...
- [Firefly引擎][学习笔记二][已完结]卡牌游戏开发模型的设计
源地址:http://bbs.9miao.com/thread-44603-1-1.html 在此补充一下Socket的验证机制:socket登陆验证.会采用session会话超时的机制做心跳接口验证 ...
- JLOI 2013 卡牌游戏
问题描述: N个人坐成一圈玩游戏.一开始我们把所有玩家按顺时针从1到N编号.首先第一回合是玩家1作为庄家.每个回合庄家都会随机(即按相等的概率)从卡牌堆里选择一张卡片,假设卡片上的数字为X,则庄家首先 ...
- cocos2d-x 卡牌翻牌效果的实现
转自:http://blog.csdn.net/yanghuiliu/article/details/9115833 这个能实现翻牌的action就是CCOrbitCamera. static CCO ...
- [JLOI2013]卡牌游戏
[题目描述 Description] N个人坐成一圈玩游戏.一开始我们把所有玩家按顺时针从1到N编号.首先第一回合是玩家1作为庄家.每个回合庄家都会随机(即按相等的概率)从卡牌堆里选择一张卡片,假设卡 ...
- [bzoj3191] [JLOI2013]卡牌游戏
概率DP. 首先由题解可得>_<,胜出概率只与剩余人数.与庄家的相对位置有关. 所以设f[i][j]表示剩下i个人,从庄家开始第j个人的胜利概率... 根据卡牌一通乱搞即可... #inc ...
- bzoj 3191: [JLOI2013]卡牌游戏
Description N个人坐成一圈玩游戏.一开始我们把所有玩家按顺时针从1到N编号.首先第一回合是玩家1作为庄家.每个回合庄家都会随机(即按相等的概率)从卡牌堆里选择一张卡片,假设卡片上的数字为X ...
随机推荐
- Spring源码由浅入深系列六 CreateBean过程
- C语言进阶学习第三章
以下记录动态内存分配: 1.malloc和free malloc和free分别用于执行动态内存分配和释放.这些函数维护一个可用内存池,当一个程序需要一些内存时,调用malloc函数,malloc从内存 ...
- 使用Beyond Compare作为Perforce默认的文件比较工具
使用perforce自带的文件比较工具有时候会遇到乱码的情况,如下: 暂时不知道如何解决上述问题,因此想换个文件比对工具,比如Beyond Compare. 设定位置:Edit->prefere ...
- bagging和boosting以及rand-forest
bagging: 让该学习算法训练多轮,每轮的训练集由从初始的训练集中随机取出的n个训练样本组成,某个初始训练样本在某轮训练集中可以出现多次或根本不出现,训练之后可得到一个预测函数序列h_1,⋯ ⋯h ...
- VS新建工程或者新建项时 出现未定义标识符号
VS新建工程或者新建项时 出现未定义标识符号,编译之后不影响运行,但是看着很不舒服,影响效率. 解决办法:属性--->VC++目录-->包含目录-->编辑,将自己所用QT的inclu ...
- java 8 lambda函数
1 为什么要引进lambda函数 可以简化编码,将事情更多的交给编译器,让编译器帮我们推断我们写的代码的完整形式. 2 lambda函数的语法 2.1 -> (arg1, arg2) -> ...
- neo4j采坑记
1.安装后启动不起来,解决方案: https://stackoverflow.com/questions/38607283/failed-to-start-neo4j-service 2.一直启动不 ...
- 5个CSS3技术实现设计增强
层叠样式表(css)是Web设计的一种语言,CSS的下一代版本CSS3已经蓄势待发.你是否可望开始使用它们却又不知从何下手呢?虽然还有一些新属性没有得到官方的确认,但是一些浏览器已经开始支持来自CSS ...
- 21个CSS技巧
级联样式表(CSS)在当代Web设计中已经成为重要的环节,如果没有CSS现在的网站将像10年前一样不堪入目.随着CSS技术的普及,越来越多的高质量CSS教程涌入互联网,让我们的学习更加方便. 1.CS ...
- 实时收集Storm日志到ELK集群
背景 我们的storm实时流计算项目已经上线几个月了,由于各种原因迟迟没有进行监控,每次出现问题都要登录好几台机器,然后使用sed,shell,awk,vi等各种命令来查询原因,效率非常低下,而且有些 ...