水题挑战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张牌能覆盖第二副牌的第 ...
随机推荐
- 玩命学JVM(二)—类加载机制
前言 Java程序运行图: 上一篇玩命学JVM(一)-认识JVM和字节码文件我们简单认识了 JVM 和字节码文件.那JVM是如何使用字节码文件的呢?从上图清晰地可以看到,JVM 通过类加载器完成了这一 ...
- 074 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 06 综合案例-数组移位-主方法功能3的实现
074 01 Android 零基础入门 01 Java基础语法 09 综合案例-数组移位 06 综合案例-数组移位-主方法功能3的实现 本文知识点:综合案例-数组移位-主方法功能3的实现 说明:因为 ...
- Java知识系统回顾整理01基础06数组03排序
一.选择法排序 选择法排序的思路: 把第一位和其他所有的进行比较,只要比第一位小的,就换到第一个位置来 比较完后,第一位就是最小的 然后再从第二位和剩余的其他所有进行比较,只要比第二位小,就换到第二个 ...
- Thymeleaf 异常:Exception processing template "index": An error happened during template parsing (template: "class path resource [templates/index.html]")
Spring Boot 项目,在 Spring Tool Suite 4, Version: 4.4.0.RELEASE 运行没有问题,将项目中的静态资源和页面复制到 IDEA 的项目中,除了 IDE ...
- 成理信安协会反序列化01-利用fastcoll实现md5碰撞
虽然是反序列化的题目,但主要考点在利用fastcoll实现md5碰撞. 直接上源码 <?php show_source(__FILE__); class CDUTSEC { public $va ...
- 让我们创建屏幕- Android UI布局和控件
下载LifeCycleTest.zip - 278.9 KB 下载ViewAndLayoutLessons_-_Base.zip - 1.2 MB 下载ViewAndLayoutLessons_-_C ...
- 跨时代的MySQL8.0新特性解读
目录 MySQL发展历程 MySQL8.0新特性 秒级加列 性能提升 文档数据库 SQL增强 共用表表达式(CTEs) 不可见索引(Invisible Indexes) 降序索引(Descending ...
- 多测师讲解selenium_输入性弹框定位_高级讲师肖sir
#输入性弹框from selenium import webdriverfrom time import sleepdrvier=webdriver.Chrome()url='file:///F:\d ...
- Mac快捷键整理(随时更新)
一.文字编辑 快捷键 含义 解释 control + A 到行首 A没找到对应单词,暂时认为A是字母表的开始 control + E 到行尾 E是end的缩写
- java基础知识总结(续写)
1.两个容易搞混的C盘文件夹 文件名 描述 Progrm Files 默认存储的64位软件 Progrm Files(x86) 默认存储32位软件 2.常用基础DOS命令(Windows+R打开命令) ...