$Luogu$

$Sol$

暴力十分显然叭.正解不是很好想.

我最开始想维护所有色调的客栈的前缀和后缀,然后每扫到一个最低消费合法的就统计一次答案.但是这样会重复计数,两个合法客栈之间有几个消费合法的客栈它们就会被算几次.既然喝咖啡的客栈不能作为计数的基准点,那就换一个叭.换成前一个住宿的客栈或后一个都可以,下面写的是以后一个客栈为基准点的做法:

从$1$扫到$N$,记录$sum[i]$为扫过的色调为$i$的客栈有多少个.$hf[i]$扫过的色调为$i$的和现在这个客栈之间有最低消费不大于$p$的客栈的客栈数.维护$so\ easy.$

$Code$

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<algorithm>
#define il inline
#define Rg register
#define go(i,a,b) for(Rg int i=a;i<=b;++i)
#define yes(i,a,b) for(Rg int i=a;i>=b;--i)
#define mem(a,b) memset(a,b,sizeof(a))
#define ll long long
#define db double
#define inf 2147483647
using namespace std;
il int read()
{
Rg int x=0,y=1;char c=getchar();
while(c<'0'||c>'9'){if(c=='-')y=-1;c=getchar();}
while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+c-'0';c=getchar();}
return x*y;
}
const int N=60;
int n,k,p,s[N],hf[N];
ll as;
int main()
{
n=read(),k=read(),p=read();
go(i,1,n)
{
Rg int col=read(),cos=read();
if(cos<=p)
go(j,0,k)hf[j]=s[j];
as+=hf[col];
s[col]++;
if(cos<=p)hf[col]++;
}
printf("%lld\n",as);
return 0;
}

最新文章

  1. Android SDK 在线更新镜像服务器资源
  2. 【转帖】嵌入式4412开发板QT5.7编译安装到arm
  3. 编写一个Singleton程序(单例)
  4. View绘制过程理解
  5. eclipse中的任务标记(TODO、FIXME、XXX)
  6. PowerDesigner的使用二
  7. 并发编程 12—— 任务取消与关闭 之 shutdownNow 的局限性
  8. xss跨站实例总结
  9. JiaThis WordPress分享插件安装全攻略
  10. dij最短路优先队列堆的时候,加边
  11. qml支持多平台的编译--尤其对于需要支持xp的情况
  12. 说说自己对RESTful API的理解s
  13. [C入门 - 游戏编程系列] 贪吃蛇篇(六) - 蛇实现
  14. [Android4.4.3] Nubia Z5S Mokee4.4.3 RC2.0 by syhost
  15. HDU 2202 最大三角形
  16. vue项目中使用ueditor
  17. JS数组reduce()方法详解及高级技巧
  18. webpack基础小结。
  19. 「SDOI2014」向量集 解题报告
  20. java 打印水仙花数

热门文章

  1. oracle函数 current_timestamp
  2. 记一次sublime text3更新 注册码失效问题和永久解决~
  3. oracle使用TKPROF 工具来查询SQL性能状态
  4. HDU 1114 完全背包 HDU 2191 多重背包
  5. 2019-10-5-dotnet-core-获取-MacAddress-地址方法
  6. 智课雅思短语---三、unshakable duty
  7. JPA进行insert操作时会首先select吗
  8. Vue 项目构建完成 ----发布项目
  9. H3C 多路径网络中环路产生过程(1)
  10. JS 逻辑运算符 ||、 &amp;&amp;, 位运算符 |、&amp;