水题挑战1:NOIP 2013 选择客栈
丽江河边有\(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 选择客栈的更多相关文章
- 水题挑战4: luogu P1280 尼克的任务
题目描述 尼克每天上班之前都连接上英特网,接收他的上司发来的邮件,这些邮件包含了尼克主管的部门当天要完成的全部任务,每个任务由一个开始时刻与一个持续时间构成. 尼克的一个工作日为 \(n\) 分钟,从 ...
- 水题挑战3: NOIP 2017 宝藏
参与考古挖掘的小明得到了一份藏宝图,藏宝图上标出了 \(n\) 个深埋在地下的宝藏屋, 也给出了这 \(n\) 个宝藏屋之间可供开发的 \(m\) 条道路和它们的长度. 小明决心亲自前往挖掘所有宝藏屋 ...
- 水题挑战2 :NOIP提高组 2011 聪明的质监员
小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 \(n\) 个矿石,从\(1\) 到 \(n\) 逐一编号,每个矿石都有自己的重量 \(w_i\) 以及价值 \(v_i\) .检验矿 ...
- noip 2011 选择客栈
题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均 ...
- 水题挑战6: CF1444A DIvision
A. Division time limit per test1 second memory limit per test512 megabytes inputstandard input outpu ...
- 历年NOIP水题泛做
快noip了就乱做一下历年的noip题目咯.. noip2014 飞扬的小鸟 其实这道题并不是很难,但是就有点难搞 听说男神错了一个小时.. 就是$f_{i,j}$表示在第$i$个位置高度为$j$的时 ...
- 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 ...
- 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 ...
- noip模拟赛 水题
题目描述 LYK出了道水题. 这个水题是这样的:有两副牌,每副牌都有n张. 对于第一副牌的每张牌长和宽分别是xi和yi.对于第二副牌的每张牌长和宽分别是aj和bj.第一副牌的第i张牌能覆盖第二副牌的第 ...
随机推荐
- python3 连接数据库~
~目前记录的是针对python3写的数据库连接,不适用于pyhon2.python3如果想要与数据库进行连接,则需要先下载对应各数据库的插件包,然后导入包.python3的插件下载地址:https:/ ...
- 【Python】数字与运算符
数据类型与运算符 数字 / 浮点除 // 整数除 ** 乘方 多种混合类型运算数的运算会把整数转换为浮点数 除了 int 和 float,Python也支持其他类型的数字,例如 Decimal 或者 ...
- 092 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 02 static关键字 02 static关键字(中)
092 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...
- CF149D Coloring Brackets
CF149D Coloring Brackets Link 题面: 给出一个配对的括号序列(如"\((())()\)"."\(()\)"等, "\() ...
- c#类(class)
类 类的定义是以关键字class开始的,后面跟类的名称,类的主题包含一个花括号里,下面是类定义的一般格式. <access specifier> class class_name { // ...
- 使用git 版本控制的代码在线修调试,如何还原
在线调试: 先切换成www用户进入项目的根目录比如/data/wwwroot/website su www cd /data/wwwroot/website vi ./api/controllers/ ...
- MySQL 8 新特性之Clone Plugin
Clone Plugin是MySQL 8.0.17引入的一个重大特性,为什么要实现这个特性呢?个人感觉,主要还是为Group Replication服务.在Group Replication中,添加一 ...
- selenium元素定位学习笔记
一,定位原则 稳定 简单灵活 唯一 WebDriver提供了两种方式来定位页面元素,分别是find_element_by_XXX和find_elements_by_XXX.第一种方式的结果是在正常情况 ...
- spring boot:swagger3的安全配置(swagger 3.0.0 / spring security / spring boot 2.3.3)
一,swagger有哪些环节需要注意安全? 1,生产环境中,要关闭swagger application.properties中配置: springfox.documentation.swagger- ...
- Java9系列第6篇-Stream流API的增强
我计划在后续的一段时间内,写一系列关于java 9的文章,虽然java 9 不像Java 8或者Java 11那样的核心java版本,但是还是有很多的特性值得关注.期待您能关注我,我将把java 9 ...