news 2026/5/2 13:27:23

历年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/4/23 23:49:27

深度学习毕设项目推荐-基于python-CNN卷积神经网络的水果识别基于机器学习卷积神经网络的水果识别

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

作者头像 李华
网站建设 2026/4/30 20:55:37

深度学习毕设项目推荐-基于python-CNN卷积神经网络对土豆疾病识别

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

作者头像 李华
网站建设 2026/5/1 5:07:38

深度学习毕设项目:通过python_CNN卷积神经网络对鸡蛋是否破损识别

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

作者头像 李华
网站建设 2026/4/20 14:26:58

NSSCTF2026年1月8日每日一练之[第五空间 2021]WebFTP

开启环境&#xff0c;进入页面得到先进行目录扫描 python dirsearch.py -u http://node4.anna.nssctf.cn:26891/扫描得到看到phpinfo.php&#xff0c;猜测可能存在php版本等相关敏感信息&#xff0c;访问一下搜索ctf或者flag&#xff0c;可以得到最终结果得到最终结果 NSSCTF{b…

作者头像 李华
网站建设 2026/5/1 8:41:11

LangGraph1.0实战:构建自动邮件处理智能体,大模型应用开发指南

本文详细介绍了如何使用LangGraph1.0构建自动邮件处理智能体&#xff0c;展示了状态管理、节点、边、条件路由和中断机制等核心技术的实战应用。通过定义智能体状态、编写节点函数、构建智能体图和测试验证&#xff0c;实现了一个能够自动分类邮件、处理Bug报告、搜索知识库生成…

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

NAT技术:互联网连接的隐形桥梁

目录 一、NAT 技术&#xff1a;从地址短缺到连接复用 1、背景&#xff1a;IPv4 地址枯竭与私有地址的诞生 2、基本 NAT&#xff08;Basic NAT&#xff09;&#xff1a;一对一地址转换 工作原理&#xff1a; 示例&#xff1a; 局限性&#xff1a; 3、NAPT&#xff08;Net…

作者头像 李华