历年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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1131621.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java毕设全套源码+文档】基于springboot的毕业文档管理系统设计与实现(丰富项目+远程调试+讲解+定制)

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

电商智能剪辑工具怎么选?2025 年最值得推荐的智能剪辑软件深度分析

在电商进入“内容密集投放”阶段后&#xff0c;一个现实问题被越来越多品牌反复验证&#xff1a;不是没预算&#xff0c;而是素材生产跟不上投放节奏。传统拍摄 人工剪辑模式&#xff0c;正在成为 ROI 的隐形杀手。这也是为什么&#xff0c;越来越多电商品牌开始主动搜索 「电…

Meta豪掷数十亿美元闪电收购Manus:一场闪电交易背后的AI困局与豪赌

2025年末&#xff0c;科技界最引人注目的交易并非来自芯片、自动驾驶或云计算&#xff0c;而是一场围绕一款争议性AI产品的闪电并购——Meta以接近20亿美元的估值全资收购初创公司Manus。从首次接触到达成协议&#xff0c;整个过程仅耗时十余天&#xff0c;速度之快令业内震惊。…

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

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

【Java毕设全套源码+文档】基于springboot的餐厅管理系统设计与实现(丰富项目+远程调试+讲解+定制)

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

2026年人工智能领域CCF推荐B类期刊全攻略:带你了解人工智能领域CCF推荐B类期刊NC、NN、PR、TACL

2026人工智能方向CCF推荐B类期刊全攻略投稿选刊犯难&#xff1f;带你了解人工智能领域CCF推荐期刊全貌&#xff01;中国计算机学会&#xff08;CCF&#xff09;中国计算机学会&#xff08;CCF&#xff09;推荐国际学术期刊目录已成为国内计算机领域学术评价的重要参考标准&…

深度学习计算机毕设之通过python_CNN卷积神经网络对辣椒类别识别

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

【计算机毕业设计案例】通过python_CNN卷积神经网络对辣椒类别识别

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

深度学习毕设项目:通过python_CNN卷积神经网络对辣椒类别识别

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

2026必备!9个一键生成论文工具,助继续教育学生轻松写论文!

2026必备&#xff01;9个一键生成论文工具&#xff0c;助继续教育学生轻松写论文&#xff01; AI 工具如何改变论文写作方式&#xff1f; 随着人工智能技术的不断进步&#xff0c;越来越多的教育工作者和学生开始借助 AI 工具来提升论文写作效率。尤其是在继续教育领域&#xf…

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

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

【计算机毕业设计案例】通过python_CNN卷积神经网络对鸡蛋是否破损识别

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

mysql怎么查看

通过以下命令查看 mysql 数据库&#xff1a;连接到服务器&#xff1a;mysql -u 用户名 -p 密码运行 show databases; 命令获取所有现有数据库选择数据库&#xff1a;use 数据库名;查看表&#xff1a;show tables;查看表结构&#xff1a;describe 表名;查看数据&#xff1a;sele…

vivado hls设计优化(十五)

一、循环优化 1.循环可以流水线化&#xff0c;可以展开&#xff0c;可以部分展开&#xff0c;可以扁平化&#xff0c;可以合并。 2.对于循环的索引index变量&#xff0c;避免使用全局变量&#xff0c;这个不利于优化。二、变量循环边界 1.循环的边界如果是变量&#xff0c;将禁…

救命神器!自考必用9大AI论文平台深度测评

救命神器&#xff01;自考必用9大AI论文平台深度测评 自考论文写作的“救星”来了&#xff1a;AI平台测评全面解析 随着自考人数逐年攀升&#xff0c;论文写作成为众多考生必须面对的难题。从选题构思到文献检索&#xff0c;从逻辑梳理到格式排版&#xff0c;每一个环节都可能成…

用Hugging Face微调医疗BERT模型

&#x1f4dd; 博客主页&#xff1a;jaxzheng的CSDN主页 医疗BERT微调&#xff1a;在数据稀缺与隐私保护下的创新路径 目录 医疗BERT微调&#xff1a;在数据稀缺与隐私保护下的创新路径 引言&#xff1a;医疗NLP的破局点 一、现在时&#xff1a;微调实践的现状与隐性成本 1.1 当…

IM 即时通讯系统消息 有序性与可靠性 的全链路设计与工程实现

在 IM 聊天系统中,消息不丢、不重、不乱序 是最核心、也是最难实现的目标之一。 本文从 架构设计 → 协议机制 → 数据模型 → Java 工程实现 全链路展开,给出一套可直接落地的 企业级 IM 消息有序性与可靠性解决方案。 一、问题背景与设计目标 1. IM 系统面临的核心挑战 在…

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

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

【课程设计/毕业设计】通过python_CNN卷积神经网络对鸡蛋是否破损识别

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

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

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