丽江河边有\(n\) 家很有特色的客栈,客栈按照其位置顺序从 \(1\) 到 \(n\) 编号。每家客栈都按照某一种色调进行装饰(总共 \(k\) 种,用整数 \(0 \sim k-1\) 表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费。

两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中。晚上,他们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括他们住的客栈),且咖啡店的最低消费不超过 \(p\) 。

他们想知道总共有多少种选择住宿的方案,保证晚上可以找到一家最低消费不超过 \(p\) 元的咖啡店小聚。

输入格式

共 \(n+1\) 行。

第一行三个整数 \(n, k, p\),每两个整数之间用一个空格隔开,分别表示客栈的个数,色调的数目和能接受的最低消费的最高值;

接下来的 \(n\) 行,第 \(i+1\) 行两个整数,之间用一个空格隔开,分别表示 \(i\) 号客栈的装饰色调 \(a_i\) 和 \(i\) 号客栈的咖啡店的最低消费 \(b_i\)。

输出格式

一个整数,表示可选的住宿方案的总数。

输入输出样例

输入 #1

5 2 3

0 5

1 3

0 2

1 4

1 5

输出 #1

3

说明/提示

样例解释

2 人要住同样色调的客栈,所有可选的住宿方案包括:住客栈\(①③,②④,②⑤,④⑤\),但是若选择住 \(4,5\)号客栈的话,\(4,5\) 号客栈之间的咖啡店的最低消费是 \(4\) ,而两人能承受的最低消费是 \(3\) 元,所以不满足要求。因此只有前 \(3\) 种方案可选。

数据范围

对于 \(30\%\)的数据,有 \(n \leq 100\) ;

对于 \(50\%\)的数据,有 \(n \leq 1\,000\);

对于 \(100\%\)的数据,有 \(2 \leq n \leq 2 \times 10^5\) ,\(1 \leq k \leq 50\),\(0 \leq p \leq 100\) \(0 \leq b_i \leq 100\)

SOLUTION

这题还是比较简单的一道noip...acmer的满满回忆

1.一个比较暴力的写法,就是大约\(n^2\times k\) 的效率,用头尾两个指针,对每一个颜色跑满整个序列,大约\(50 pts\) .(偷懒的博主挣扎在高数泥潭里无法自拔,便懒得写了 )

2.我们考虑从前走到后 \(:\)

我们用 \(f[i][j]\) 来表示前 \(i\) 个位置,对于颜色\(j\)的客栈的答案数.

\(s[i][j]\) 表示前\(i\)个元素,颜色为\(j\)的客栈数.

\(pos\) 表示离当前位置最近的客栈底下的价格小于等于 \(p\) 咖啡店.

我们考虑每次走到一个位置 \(i\) : 记它的颜色\(c[i]\) ,则只要在位置是\(pos\)之前的颜色相同的,都会构成一个方案。 即:

当 \(pos\) 与 \(i\) 不同

\(f[i][c[i]]=f[i-1][c[i]]+s[pos][c[i]]\)

当 \(pos\)与 \(i\) 相同

\(f[i][c[i]]=f[i-1][c[i]]+s[pos-1][c[i]]\)

其他颜色位置\(i\)从\(i-1\)继承而来就好了

具体见代码

#include<bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for(int i=a;i<=b;i++)
#define _(d) while(d(isdigit(ch=getchar())))
template <class T> void g(T&t){T x,f=1;char ch;_(!)ch=='-'?f=-1:f;x=ch-48;_()x=x*10+ch-48;t=f*x;}
typedef long long ll;
const int N=200004,K=52;
int n,k,p,c[N],v[N],s[N][K];ll f[N][K];
int main(){
g(n),g(k),g(p);
rep(i,1,n) g(c[i]),g(v[i]);
rep(i,1,n){
rep(j,0,k) s[i][j]=s[i-1][j];
s[i][c[i]]++;
}
int pos=0;
rep(i,1,n){
if(v[i]<=p) pos=i;
rep(j,0,k) f[i][j]=f[i-1][j];
if(pos!=i) f[i][c[i]]=f[i-1][c[i]]+s[pos][c[i]];
else f[i][c[i]]=f[i-1][c[i]]+s[pos-1][c[i]];
}
ll ans=0;
rep(i,0,k) ans+=f[n][i];
printf("%lld\n",ans);
return 0;
}

水题挑战1:NOIP 2013 选择客栈的更多相关文章

  1. 水题挑战4: luogu P1280 尼克的任务

    题目描述 尼克每天上班之前都连接上英特网,接收他的上司发来的邮件,这些邮件包含了尼克主管的部门当天要完成的全部任务,每个任务由一个开始时刻与一个持续时间构成. 尼克的一个工作日为 \(n\) 分钟,从 ...

  2. 水题挑战3: NOIP 2017 宝藏

    参与考古挖掘的小明得到了一份藏宝图,藏宝图上标出了 \(n\) 个深埋在地下的宝藏屋, 也给出了这 \(n\) 个宝藏屋之间可供开发的 \(m\) 条道路和它们的长度. 小明决心亲自前往挖掘所有宝藏屋 ...

  3. 水题挑战2 :NOIP提高组 2011 聪明的质监员

    小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 \(n\) 个矿石,从\(1\) 到 \(n\) 逐一编号,每个矿石都有自己的重量 \(w_i\) 以及价值 \(v_i\) .检验矿 ...

  4. noip 2011 选择客栈

    题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均 ...

  5. 水题挑战6: CF1444A DIvision

    A. Division time limit per test1 second memory limit per test512 megabytes inputstandard input outpu ...

  6. 历年NOIP水题泛做

    快noip了就乱做一下历年的noip题目咯.. noip2014 飞扬的小鸟 其实这道题并不是很难,但是就有点难搞 听说男神错了一个小时.. 就是$f_{i,j}$表示在第$i$个位置高度为$j$的时 ...

  7. HDU 4788 Hard Disk Drive (2013成都H,水题)

    Hard Disk Drive Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  8. HDU 4772 Zhuge Liang's Password (2013杭州1003题,水题)

    Zhuge Liang's Password Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/O ...

  9. noip模拟赛 水题

    题目描述 LYK出了道水题. 这个水题是这样的:有两副牌,每副牌都有n张. 对于第一副牌的每张牌长和宽分别是xi和yi.对于第二副牌的每张牌长和宽分别是aj和bj.第一副牌的第i张牌能覆盖第二副牌的第 ...

随机推荐

  1. CDH5部署三部曲之二:部署和设置

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  2. lua 1.1 源码阅读总结

    GC 1. 怎么回收的lua 中所有已经分配的数据都会用一些指令的数据结构来记录,当需要回收时,先遍历当前栈内所有 object,把 ref 标志位打上 1,遍历符号表(这部分不能回收),反符号表中的 ...

  3. golang不想http自动处理重定向的解决方案

    目录 前言 解决方案 结论 前言     有时候发送http请求不想让库自动帮忙处理重定向,库里面默认的是会把所有重定向都完成一遍,结果就是最后一个没有重定向的请求的结果.因此需要一种方案直接获取首次 ...

  4. node将js中的json对象生成到新的excel表中

    第一步  安装依赖包   npm install json2xls fs 第二步  创建node.js文件,文件内代码如下: var fs = require('fs'); var path = re ...

  5. 多测师讲解性能测试_面试题_001高级讲师肖sir

    什么叫做性能测试?1. 软件的性能是软件的一种非功能特性,它关注的不是软件是否能够完成特定的功能,所以一般来说性能测试介入的时机是在功能测试完成之后.另外,由定义中的及时性可知性能也是一种指标,可以 ...

  6. Python3.7有什么新变化

    https://docs.python.org/zh-cn/3/whatsnew/3.7.html

  7. 我是先学C语言还是先学C++,实不相瞒,鱼和熊掌可兼得!

    这是最近一周时间几个读者小伙伴所提的问题,我顺手截了两个图. 实不相瞒,这类问题之前也经常看到.     每次遇到这种问题,看起来很简单,但是打字一时半会还真说不清,想想今天周末了,写一篇文章来统一聊 ...

  8. 闭嘴,给你一个数!1分钟,学完C语言指针,不扎手只扎心的针!

    序言 指针是C语言学习者绕不过的一道坎,也是C语言学习者不得绕过的一道坎.辨别一个人C语言学的好赖就看他对指针的理解怎么样.指针内容也是工作面试经常问到的问题.本文将带你重新认识那个绊倒你的指针,以解 ...

  9. spring boot:多个filter/多个interceptor/多个aop时设置调用的先后顺序(spring boot 2.3.1)

    一,filter/interceptor/aop生效的先后顺序? 1,filter即过滤器,基于servlet容器,处于最外层, 所以它会最先起作用,最后才停止 说明:filter对所有访问到serv ...

  10. spring boot:用shardingjdbc实现多数据源的分库分表(shardingsphere 4.1.1/spring boot 2.3.1)

    一,shardingjdbc的用途 1,官方站介绍: Apache ShardingSphere 是一套开源的分布式数据库中间件解决方案组成的生态圈, 它由 JDBC.Proxy 和 Sidecar( ...