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 选择客栈 直通 思路: ①看题,我们可以发现一个显然的性质,即当最左边的客栈向右移动时,最右边的客栈时单调向右的,并且右端点往右的客栈也符合要求.(因为只要左侧有一个满足的,右边的自然可以 ...
随机推荐
- hdu 1053 Entropy (哈夫曼树)
Entropy Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...
- mysql5.7 MRG集群部署学习
文章目录 1.安装mysql 2.修改配置文件: 3.安装group_replicatin插件,启动group_replication 4.添加节点node-02 node-03: 有关复制组的相关原 ...
- 【NOIP模拟赛】chess 建图+spfa统计方案数
似乎弗洛伊德和迪杰斯特拉都干不了统计方案数,spfa的话就是不断入队就好. #include <cstdio> #include <cstring> #include < ...
- [USACO Hol10] 臭气弹 图上期望概率dp 高斯
记住一开始和后来的经过是两个事件因此概率可以大于一 #include<cstdio> #include<iostream> #include<cstdlib> #i ...
- ng双向数据绑定
http://blog.csdn.net/callmekongkong/article/details/54601585
- PHP报错Cannot adopt OID in UCD-SNMP-MIB、 LM-SENSORS-MIB
Cannot adopt OID in UCD-SNMP-MIB: Cannot adopt OID in LM-SENSORS-MIB: lmTempSensorsValue 运行PHP遇到这些错误 ...
- Join/remove server into/from windows domain PS script
Join server into windows domain PS script $username = "ad-domain\admin" $Password = " ...
- flume高级组件及各种报错
1,one source two channel 创建conf文件,内容如下: #定义agent名, source.channel.sink的名称 access.sources = r1 access ...
- 使用apache构建OpenStack内部yum源
安装apache yum install httpd -y 上传openstack-mitaka-rpms.tar包,链接:http://pan.baidu.com/s/1kVA1wKv 密码:q26 ...
- Red-Black Tree
A red-black tree is a Binary Search Tree that satisfy the red-black tree properties: 1. Every node i ...