NOIP2011选择客栈
n家客栈,1~n编号,每家按照某一种色调装饰,共k种,每家客栈都设有咖啡店,每家咖啡店均有各自的最低消费
两位游客,要求住在颜色相同,且不是同一个客栈,在两人的客栈间选择咖啡店(包括他们住的客栈),要求最低消费不超过p
求有多少种方案
输入格式:
第一行n,k,p,表示客栈的个数,色调数目,和可接受的最低消费的最高值
接下来n行,分别表示第i号客栈的色调和咖啡店的最低消费
输出格式
一个整数,表示方案总数
输入样例#1:
5 2 3
0 5
1 3
0 2
1 4
1 5
输出样例#1:
3
1 2 3 4 5
0 1 0 1 1
5 3 2 4 5
解题思路:
基本暴力思路是手动搜索出现过的,和当前位置颜色相同的客栈的位置
再依次判断
这样很慢。显然是不行的
然后我们可以想到这样一个思路(性质?):
如果我们累计不算当前位置,之前所出现过的当前颜色的总次数
那么如果可行,我们就要在总方案数上累加这个数。我们能注意到的是,每出现一个颜色,所需要检测的状态只增加了上一个同样颜色的位置和当前位置是否满足题意,需要方案数+1
但是对于是否可行这个问题,我们就需要开一个辅助数组记录当前颜色上一次出现的位置
但是如果不可行呢?继续向前,上上一个位置,上上上一个位置都不可行呢?
这就提示我们要开第二个辅助数组,记录方案数,这个数组的值只有满足了上一个位置和当前位置这一决策符合题意时才能更新,这样保证了我们每次累加的方案数永远都是合法的未知的方案数
于是又出现了新的问题:拿什么值去更新?
我们可以发现,若是上一个位置和当前位置可行,那么当前位置与此前所有该颜色的位置匹配都可行,这也就是说,在该情况下,我们累计的是不算当前位置,当前颜色出现过的总次数
这也就是我们要拿来去更新辅助数组2的值
于是我们再开第三个辅助数组,记录不算当前位置,该颜色出现过的次数
接着代码的实现就非常容易了
#include<bits/stdc++.h>
using namespace std;
const int maxn = ;
struct enkidu {
int color, cost;
}a[maxn];
int n, k, p;
int color_cnt[], color_last[];
int color_num[];
int last_acc;
int ans = ;
bool vis[maxn]; inline int read() {
int x = , y = ;
char ch = getchar();
while(!isdigit(ch)) {
if(ch == '-') y = -;
ch = getchar();
}
while(isdigit(ch)) {
x = (x << ) + (x << ) + ch - '';
ch = getchar();
}
return x * y;
} int main() {
memset(color_cnt, , sizeof(color_cnt));
memset(color_num, , sizeof(color_num));
n = read(), k = read(), p = read();
for(int i = ; i <= n; ++i)
a[i].color = read(), a[i].cost = read();
for(int i = ; i <= n; ++i) {
int cl = a[i].color;
if(a[i].cost <= p) last_acc = i;//求上一个小于p的位置
if(vis[cl]) {
if(color_last[cl] <= last_acc) //若上一个当前颜色的位置比上一个小于p的位置小,则说明目前当前颜色出现过的总次数将是要累加的答案
color_num[cl] = color_cnt[cl];//否则要累加的是上一个满足要求的当前颜色的位置记录的出现过的次数
color_last[cl] = i;//更新上一个当前颜色出现的位置
ans += color_num[cl];//累加答案
color_cnt[cl]++;//统计到目前为止,当前颜色出现的次数
}
else if(!vis[cl]) {//若当前颜色从未见过
color_last[cl] = i;
color_cnt[cl]++;
vis[cl] = ;
}
}
cout << ans << '\n';
return ;
}
NOIP2011选择客栈的更多相关文章
- NOIP2011选择客栈[递推]
题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均 ...
- [NOIP2011] 选择客栈
题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均 ...
- 【组合数】[NOIP2011]选择客栈[c++]
题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均 ...
- 一本通1546【NOIP2011】选择客栈
1546:NOIP2011 选择客栈 时间限制: 1000 ms 内存限制: 524288 KB 题目描述 丽江河边有 n 家很有特色的客栈,客栈按照其位置顺序从 1 到 n 编号. ...
- 【11NOIP提高组】选择客栈(信息学奥赛一本通 1546)(洛谷 1311)
题目描述 丽江河边有nn家很有特色的客栈,客栈按照其位置顺序从 11到nn编号.每家客栈都按照某一种色调进行装饰(总共 kk 种,用整数 00 ~k-1k−1 表示),且每家客栈都设有一家咖啡店,每家 ...
- 【五一qbxt】day7-2 选择客栈
停更20天祭qwq(因为去准备推荐生考试了一直在自习qwq) [noip2011选择客栈] 这道题的前置知识是DP,可以参考=>[五一qbxt]day3 动态规划 鬼知道我写的是什么emm 这道 ...
- 洛谷P1311 [NOIP2011提高组Day1T2]选择客栈
P1311 选择客栈 题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一 ...
- 选择客栈noip2011
哈,没想到吧.今天居然有两篇(算什么,厕所读物吗 选择客栈 本题的更优解请跳转zt 这题11年,刚改2day. 对于30% 的数据,有 n ≤100: 对于50% 的数据,有 n ≤1,000: 对于 ...
- Noip2011 提高组 选择客栈
P1311 选择客栈 直通 思路: ①看题,我们可以发现一个显然的性质,即当最左边的客栈向右移动时,最右边的客栈时单调向右的,并且右端点往右的客栈也符合要求.(因为只要左侧有一个满足的,右边的自然可以 ...
随机推荐
- 大步小步算法模板题, poj2417
大步小步模板 (hash稍微有一点麻烦, poj不支持C++11略坑) #include <iostream> #include <vector> #include <c ...
- 利用FFT来进行字符串匹配
给定串A和串B,A由26个小写字母构成,B由?和26个小写字母构成 ?可以和任意字符匹配 求A中出现了多少次B 这里可以使用fft做法,定义向量A和向量B 然后求A和rev(B)的卷积结果C C的第i ...
- Boosting&Bagging
Boosting&Bagging 集成学习方法不是单独的一个机器学习算法,而是通过构建多个机器学习算法来达到一个强学习器.集成学习可以用来进行分类,回归,特征选取和异常点检测等.随机森林算法就 ...
- WIndows 相关知识
Windows服务 图解WinXP局域网共享设置步骤 Win10如何搭建FTP服务器以实现快速传输文件 强大工具psexec工具用法简介 BIOS和CMOS的区别 系统CLSID简介和小技巧
- 接到新数据库时,分析业务常用的SQL语句
USE DataBaseName--清空当前GridView显示,释放内存: SELECT GETDATE() --数据库关系图 SELECT * FROM sysdiagrams --列出所有表 S ...
- 【COGS 1534】 [NEERC 2004]K小数 &&【COGS 930】 [河南省队2012] 找第k小的数 可持久化01Trie
板子题,只是记得负数加fix最方便 #include <cstdio> ,N=; namespace FIFO { <<],*S=B,*T=B; #define getc() ...
- async的用法
package com.example.administrator.myapplication; import android.os.AsyncTask; import android.util.Lo ...
- 随机洗牌算法Knuth Shuffle和错排公式
Knuth随机洗牌算法:譬如现在有54张牌,如何洗牌才能保证随机性.可以这么考虑,从最末尾一张牌开始洗,对于每一张牌,编号在该牌前面的牌中任意一张选一张和当前牌进行交换,直至洗到第一张牌为止.参考代码 ...
- [BZOJ1391]解题报告|网络流的又一类建图&Dinic的若干优化
1391: [Ceoi2008]order 有N个工作,M种机器,每种机器你可以租或者买过来. 每个工作包括若干道工序,每道工序需要某种机器来完成,你可以通过购买或租用机器来完成. 现在给出这些参数, ...
- windows支持applocker的版本
Operating system requirements The following table show the on which operating systems AppLocker fe ...