【noip2011】【codevs1135】选择客栈

时间限制: 1 s

空间限制: 128000 KB

题目描述 Description

丽江河边有 n 家很有特色的客栈,客栈按照其位置顺序从1 到n 编号。每家客栈都按照某一种色调进行装饰(总共k 种,用整数0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费。
两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中。晚上,他们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括他们住的客栈),且咖啡店的最低消费不超过p。
他们想知道总共有多少种选择住宿的方案,保证晚上可以找到一家最低消费不超过p元的咖啡店小聚。

输入描述
Input Description

共n+1 行。
第一行三个整数 n,k,p,每两个整数之间用一个空格隔开,分别表示客栈的个数,色调的数目和能接受的最低消费的最高值;
接下来的 n 行,第i+1 行两个整数,之间用一个空格隔开,分别表示i 号客栈的装饰色调和i 号客栈的咖啡店的最低消费。

输出描述
Output Description

输出只有一行,一个整数,表示可选的住宿方案的总数。

样例输入
Sample Input

5 2 3
0 5
1 3
0 2
1 4
1 5

样例输出
Sample Output

3

数据范围及提示
Data Size & Hint

【输入输出样例说明】

客栈编号
色调 
最低消费  5

2 人要住同样色调的客栈,所有可选的住宿方案包括:住客栈①③,②④,②⑤,④⑤,
但是若选择住 4、5 号客栈的话,4、5 号客栈之间的咖啡店的最低消费是 4,而两人能承受
的最低消费是 3 元,所以不满足要求。因此只有前 3 种方案可选。

【数据范围】
对于 30%的数据,有n≤100;
对于 50%的数据,有n≤1,000;
对于 100%的数据,有2≤n≤200,000,0<k≤50,0≤p≤100, 0≤最低消费≤100。

刚开始看到100%数据吓了一跳,以为自己开200000*50两个数组直接爆内存,后来冥思苦想(5分钟 233333),终于想明白——自己又一次脑残了!

事实上对于第k种颜色,假设客栈数l,当且仅当存在长为p的一个字串,其中每一项都超过期望值时,从初始值 l*(l-1)/2 中减去 p*(p-1)/2 即可,一边读一边做,因为我们只需要记录该值与期望的大小关系,并不需要具体值,故只需一个很小的数组存总数即可,注意——数组最好开到负值,否则有可能爆出。

期望复杂度O(X*N)x为一常数(操作比较多),过100数据无压力。

继续贴代码>.<

var
        t,d,o:array[-100..51] of longint;
        i,j,k,l,m,n,p,x,y:longint;

        begin
                readln(n,k,p);
                for i:=1 to n do
                begin
                        read(x,y);
                        inc(t[x]);
                        if y>p then inc(o[x])
                        else
                        begin
                                for j:=0 to k do
                                begin
                                d[j]:=d[j]+((o[j]*(o[j]-1)) div 2);
                                o[j]:=0;
                                end;
                        end;
                end;

                for j:=0 to k do
                begin
                        d[j]:=d[j]+((o[j]*(o[j]-1)) div 2);
                        o[j]:=0;
                end;

                for i:=0 to k-1 do
                d[i]:=(t[i]*(t[i]-1)) div 2 - d[i];

                for i:=0 to k-1 do
                d[i]:=d[i-1]+d[i];
                writeln(d[k-1]);
        end.

对了,网上有人说这道题是模拟,完全没看出怎么模拟,而且那些代码都比这个长= =

时间: 2024-10-22 22:04:04

【noip2011】【codevs1135】选择客栈的相关文章

[noip2011 d1t2]选择客栈

看起来noip特别喜欢考这种思维题== 题意:有n家客栈,每家客栈有一个颜色和一个花费.给定最大允许花费,选择两家颜色相同的客栈,问有多少种选择方式使得两家客栈之间至少有一家花费允许的最大值的客栈 可以想到一些 n2 甚至 n3 的方法,但显然不足以满足所有数据 考虑对于每一家客栈,从右往左扫描,找到第一家满足条件的颜色相同的客栈,其左边的所有颜色相同的客栈也就都满足条件了 所以此题可以巧妙地运用一些临时变量来记录当前可行的方案数,从而O(n)地解决问题 详见代码 #include<cstdio

【NOIP2011】选择客栈

Description 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从1 到n 编号.每家客栈都按照某一种色调进行装饰(总共k 种,用整数0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费. 两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中.晚上,他们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括他们住的客栈),且咖啡店的最低消费不超过p. 他们想知道总共有多少种选择住宿的方案,保证晚

CODEVS1135选择客栈(2011noip提高组)

题目描述:丽江河边有 n 家很有特色的客栈,客栈按照其位置顺序从1 到n 编号.每家客栈都按照某一种色调进行装饰(总共k 种,用整数0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费. 两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中.晚上,他们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括他们住的客栈),且咖啡店的最低消费不超过p.他们想知道总共有多少种选择住宿的方案,保证晚上可以找到一家

$Noip2011/Luogu1311$ 选择客栈

$Luogu$ $Sol$ 暴力十分显然叭.正解不是很好想. 我最开始想维护所有色调的客栈的前缀和后缀,然后每扫到一个最低消费合法的就统计一次答案.但是这样会重复计数,两个合法客栈之间有几个消费合法的客栈它们就会被算几次.既然喝咖啡的客栈不能作为计数的基准点,那就换一个叭.换成前一个住宿的客栈或后一个都可以,下面写的是以后一个客栈为基准点的做法: 从$1$扫到$N$,记录$sum[i]$为扫过的色调为$i$的客栈有多少个.$hf[i]$扫过的色调为$i$的和现在这个客栈之间有最低消费不大于$p$

洛谷P1311 [NOIP2011提高组Day1T2] 选择客栈

P1311 选择客栈 题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费. 两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中.晚上,他们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括他们住的客栈),且咖啡店的最低消费不超过 p . 他们想知道总共有多少种选择

NOIP2011选择客栈[递推]

题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费. 两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中.晚上,他们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括他们住的客栈),且咖啡店的最低消费不超过 p . 他们想知道总共有多少种选择住宿的方案,保证晚上可

noip2011 选择客栈

P1311 选择客栈 375通过 1K提交 题目提供者该用户不存在 标签递推2011NOIp提高组 难度普及+/提高 提交该题 讨论 题解 记录 题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费. 两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中.晚上,他们打算选择一家咖啡店

Noip2011 提高组 选择客栈

P1311 选择客栈 直通 思路: ①看题,我们可以发现一个显然的性质,即当最左边的客栈向右移动时,最右边的客栈时单调向右的,并且右端点往右的客栈也符合要求.(因为只要左侧有一个满足的,右边的自然可以选) 不妨将每种颜色的宾馆分别放到 vector 中. 然后在每个 vector 中枚举左端点,维护一个单调指针来确定右端点 (vector中的下标). 我们接下来就要快速判断一段区间是否合法,我们开一个ok数组,表示从i点开始最近的满足条件的位置(不考虑颜色). 这样的话转移就是: ok[i]=i

NOIP201106选择客栈

(本来像这种东西我都是写进程序注释里的,然而杨老师说不写就罚跑圈..所以只能写了QAQ) 第一次写博,感觉没毛线好写的,贴道水题好了QAQ(其实是因为看WXJ和LJX围着这题的测试数据讨论了半个多小时屁结论都没有) NOIP201106选择客栈 难度级别:A: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述    丽江河边有n家很有特色的客栈,客栈按照其位置顺序从1到n编号.每家客栈都按照某一种色调进行装饰(总共k种,用整数0到k-1表示)

2011 选择客栈

选择客栈 题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费. 两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中.晚上,他们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括他们住的客栈),且咖啡店的最低消费不超过 p . 他们想知道总共有多少种选择住宿的方案,