丽江河边有\(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. Centos-将文件内容输出到标准输出-cat

    cat 将文件内容输出到标准输出 相关选项 -n 显示行号,包括空行 -b 显示行号,不包括空行 -A 显示制表符为 ^I ,结尾符为 $ 应用 1. 清空文件 cat /dev/null > ...

  2. .NET 是信息技术应用创新产业重要参与者

    今天是国庆节,也是中秋节,月满中秋,举国欢庆,在这里祝各位开发者中秋国庆快乐. 放假在家就想把这几年对于.NET发展相关生态做个梳理,写一篇文章来总结一下这两年从腾讯出来自己创业,推动.NET在国内的 ...

  3. Git多人项目开发流程演练

    1. 前言 本文利用 GitHub 平台进行一个多人项目开发流程的演练,以加深课上所学内容. 参考文献:五⼤场景玩转 Git,只要这一篇就够了! 2. 初始化项目 2.1 新建远程项目 一个多人项目通 ...

  4. JS寄快递地址智能解析

    JS寄快递地址智能解析--2020年7月15日 去年做了些前端内容,最近在整理一些稍微有点用的内容,比如智能解析地址,用户只要输入:张三1351111111江苏省扬州市广陵区XX小区X楼xxx室,就能 ...

  5. 引用类型之Object

    引用类型 引用类的值(对象)是引用类型的一个实例.在ECMAScript中,引用类型是一种数据结构,用于将数据和功能组织在一起. 对象是某个特定引用类型的实例.新对象是使用new操作符后跟一个构造函数 ...

  6. vs调试程序缺少 msvcp140d.dll 解决方法

    简介一下吧: 如果只是为了解决问题请直接看第      7       点 ,谢谢. vs2013运行刚安装的opencv问题总结,尤其是电脑还很渣的情况下------花了我起码2天样子----很无奈 ...

  7. 从远程库github.com克隆代码时遇到了如下的问题:

    Warning: Permanently added the RSA host key for IP address '13.250.177.223' to the list of known hos ...

  8. 微服务 | Spring Cloud(一):从单体SSM 到 Spring Cloud

    系列文章目录 微服务 | Spring Cloud(一):从单体SSM 到 Spring Cloud 目录 系列文章目录 前言 单体式架构 微服务架构 优点 缺点 服务发现与弹性扩展 参考 前言 在微 ...

  9. linux处理l2tp协议的示意图

  10. linq 整理(前序)

    前言 对linq进行整理,分为前序.中序和后序. 前序就是一些简单的概念和模拟. 中序的话就是深挖一些思想. 后序对其进行解刨. 正文 语言集成查询 (LINQ) 是一系列直接将查询功能集成到 C# ...