news 2026/5/1 7:47:44

历年CSP-S复赛真题解析 | 2011年T2 选择客栈

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
历年CSP-S复赛真题解析 | 2011年T2 选择客栈

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总贴:历年CSP-S复赛真题解析 | 汇总


【题目来源】

洛谷:[P1311 NOIP 2011 提高组] 选择客栈 - 洛谷

【题目描述】

丽江河边有n nn家很有特色的客栈,客栈按照其位置顺序从1 11n nn编号。每家客栈都按照某一种色调进行装饰(总共k kk种,用整数0 ∼ k − 1 0 \sim k-10k1表示),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费。

两位游客一起去丽江旅游,他们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中。晚上,他们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括他们住的客栈),且咖啡店的最低消费不超过p pp

他们想知道总共有多少种选择住宿的方案,保证晚上可以找到一家最低消费不超过p pp元的咖啡店小聚。

【输入】

n + 1 n+1n+1行。

第一行三个整数n , k , p n, k, pn,k,p,每两个整数之间用一个空格隔开,分别表示客栈的个数,色调的数目和能接受的最低消费的最高值;

接下来的n nn行,第i + 1 i+1i+1行两个整数,之间用一个空格隔开,分别表示 $i $ 号客栈的装饰色调a i a_iaii ii号客栈的咖啡店的最低消费b i b_ibi

【输出】

一个整数,表示可选的住宿方案的总数。

【输入样例】

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

【输出样例】

3

【算法标签】

《洛谷 P1311 选择客栈》 #递推# #NOIP提高组# #2011#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;#defineintlonglong// 使用长整型防止溢出constintN=200005;// 定义最大数组长度intn,k,p;// n:酒店数量, k:颜色种类, p:最大预算inta[N];// a[i]:第i个酒店的颜色intb[N];// b[i]:第i个酒店的费用intnum[55][N];// num[j][i]:前i个酒店中颜色为j的酒店数量intpos[N];// pos[i]:从i向前找,第一个费用<=p的酒店位置intans;// 最终答案(满足条件的方案数)signedmain(){// 输入酒店数量、颜色种类和最大预算cin>>n>>k>>p;// 输入每个酒店的颜色和费用for(inti=1;i<=n;i++){cin>>a[i]>>b[i];// 计算前缀和:统计每种颜色出现的次数for(intj=0;j<k;j++){if(j==a[i]){// 当前酒店颜色为j,数量加1num[j][i]=num[j][i-1]+1;}else{// 其他颜色保持不变num[j][i]=num[j][i-1];}}// 记录费用<=p的最近位置if(b[i]<=p){// 当前酒店费用<=p,记录当前位置pos[i]=i;}else{// 当前酒店费用>p,继承前一个位置pos[i]=pos[i-1];}}// 统计满足条件的方案数for(inti=2;i<=n;i++){// 找到从i向前第一个费用<=p的酒店位置intt=pos[i];// 当前酒店的颜色intc=a[i];// 累加在位置t之前,颜色与当前酒店相同的酒店数量ans+=num[c][t];// 如果当前酒店本身费用<=p,需要减去自身(避免重复计算)if(pos[i]==i){ans--;}}// 输出最终答案cout<<ans<<endl;return0;}

【运行结果】

5 2 3 0 5 1 3 0 2 1 4 1 5 3
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 7:35:38

更快、更强、更实惠:谷歌正式发布Gemini 3 Flash,开启AI新纪元

2025年12月17日&#xff0c;谷歌重磅推出其Gemini 3模型家族的最新成员——Gemini 3 Flash。这款新模型以速度和效率为核心&#xff0c;实现了前沿智能与低成本、低延迟的完美结合&#xff0c;并已开始向全球用户和开发者全面推送。谷歌正式宣布推出Gemini 3 Flash&#xff0c;…

作者头像 李华
网站建设 2026/4/27 17:09:56

【Java毕设全套源码+文档】基于springboot的癌症患者交流平台设计与实现(丰富项目+远程调试+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/1 6:18:26

MySQL如何给查出的数据 加上序号

MySQL给查出的数据加序号的方法 SELECT sid,sname,gender,age,(i:i1) AS 序号 FROM student,(SELECT i:0) AS itable;或者 SET i0; SELECT sid,sname,gender,age,i:i1 AS 序号 FROM student;查询结果如图所示&#xff1a;解释说明&#xff1a; 1、(i:i1)也可以写成 i:i1 &…

作者头像 李华
网站建设 2026/4/13 3:22:30

MySQL如何删除binlog日志文件

MySQL如何删除binlog日志文件呢&#xff1f; 1、使用命令手动在操作系统中删除,但是这种删除并没有从数据库逻辑层面删除&#xff0c;数据库里还记录着这条日志&#xff0c;可能会有一些问题。 进入到MySQL数据目录下&#xff0c;rm -rf 日志文件2、使用SQL命令删除&#xff0c…

作者头像 李华
网站建设 2026/4/17 6:43:27

mysql如何创建用户并且授权

在 MySQL 中可以使用以下步骤创建用户&#xff1a; 1.使用管理员账户登录到 MySQL&#xff1a; - 打开命令行终端&#xff0c;输入以下命令以管理员身份登录 MySQL&#xff08;假设 MySQL 安装在默认位置且管理员用户为root&#xff0c;密码为your_root_password&#xff09;&a…

作者头像 李华
网站建设 2026/4/25 18:21:57

2026年转行AI大模型必备:两个高薪岗位,让你年后求职弯道超车

文章指出当前就业市场低迷&#xff0c;但春节后很快进入春招旺季&#xff0c;建议现在就开始准备。重点推荐两个普通人也能入行的AI方向&#xff1a;AI大模型应用开发师&#xff08;年薪最高72万&#xff09;和AI大模型训练师&#xff08;年薪最高45万&#xff09;。AI行业正处…

作者头像 李华