news 2026/3/27 8:56:21

USACO历年青铜组真题解析 | 2024年2月Milk Exchange

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
USACO历年青铜组真题解析 | 2024年2月Milk Exchange

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

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

适合人群:

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

附上汇总贴:USACO历年青铜组真题解析 | 汇总-CSDN博客


【题目来源】

洛谷:[P10188 USACO24FEB] Milk Exchange B - 洛谷

【题目描述】

农夫约翰有N ( 1 ≤ N ≤ 2 ⋅ 10 5 ) N(1\le N\le 2\cdot 10^5)N(1N2105)头牛排成一个圈,对于每个在1 , 2 , … , N − 1 1,2,\dots,N-11,2,,N1中的i ii,牛i ii的右边是牛i + 1 i+1i+1,而牛 N的右边是牛1 11。第i ii头牛有一个容量为a i ( 1 ≤ a i ≤ 10 9 ) a_i(1\le a_i\le 10^9)ai(1ai109)升的桶。所有的桶一开始都是满的。

每分钟,牛们会根据一个只由字符 ‘L’ 和 ‘R’ 组成的字符串**s 1 s 2 … s N s_1s_2\dots s_Ns1s2sN**来交换牛奶。如果第i ii头牛至少有1 11升牛奶,它会根据s i s_isi是 ‘L’ 还是 ‘R’,分别把1 11升牛奶传给她左边或右边的牛。所有的交换都是同时发生的(也就是说,如果一头牛的桶是满的,但她给了一升牛奶同时也收到了一升牛奶,她的牛奶量是保持不变的)。如果一头牛的总牛奶量最终超过了a i a_iai,那么多出来的牛奶就会流失。

农夫约翰想知道:经过M MM分钟**( 1 ≤ M ≤ 10 9 ) (1\le M\le 10^9)(1M109)**后,所有牛中剩余的总牛奶量是多少?

【输入】

第一行包含N NNM MM

第二行包含一个仅由字符’L’或’R’组成的字符串**s 1 s 2 … s N s_1s_2\dots s_Ns1s2sN**,表示每头牛会向哪个方向传递它们的牛奶。

第三行包含整数**a 1 , a 2 , … , a N a_1,a_2,\dots,a_Na1,a2,,aN**,即每个桶的容量。

【输出】

输出一个整数,表示M分钟后所有奶牛中牛奶的总和。

请注意,此问题中涉及的大整数大小可能需要使用**64 6464**位整数数据类型(例如,在C/C++中的“long long”)。

【输入样例】

3 1 RRL 1 1 1

【输出样例】

2

【算法标签】

《洛谷 P10188 Milk Exchange》 #USACO# #O2优化# #2024#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;intn,m;longlonga[200005],ans;string s;boolL[200005],R[200005];//L[i]=true表示点i为某个溢出结构的起点//R[i]=true表示点i为某个溢出结构的终点intmain(){cin>>n>>m;cin>>s;for(inti=0;i<n;i++){cin>>a[i];ans+=a[i];}//第一步:从左到右找出字符串s中所有的溢出结构RL,并标记其起点和终点for(inti=0;i<=n-1;i++){if(s[i]=='R'&&s[(i+1)%n]=='L'){L[i]=true;R[(i+1)%n]=true;}}//第二步:从左到右计算每个溢出结构导致的牛奶溢出for(inti=0;i<n;i++){longlongsum=0;// 每个溢出结构溢出的牛奶数量if(L[i]==true){// i号桶为某个溢出结构的起点intj=(i-1+n)%n;// 记录i号桶左边的编号jwhile(s[j]=='R'){sum+=a[j];j=(j-1+n)%n;// 继续向左}}if(R[i]==true){// i号桶为某个溢出结构的终点intj=(i+1)%n;// 记录i号桶右边的编号jwhile(s[j]=='L'){sum+=a[j];j=(j+1)%n;// 继续向右}}ans-=min(sum,(longlong)m);}cout<<ans<<endl;return0;}

【运行结果】

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

【力扣hot100题】缺失的第一个正数(12)

给你一个未排序的整数数组 nums &#xff0c;请你找出其中没有出现的最小的正整数。 请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,0] 输出&#xff1a;3 解释&#xff1a;范围 [1,2] 中的数字都在数组…

作者头像 李华
网站建设 2026/3/25 20:30:40

每日 AI 评测速递来啦(1.8)

司南Daily Benchmark 专区今日上新&#xff01; RFC Bench 一个用于在真实新闻语境下评估大语言模型金融虚假信息识别能力的评测基准&#xff0c;以段落级别为评测粒度&#xff0c;刻画金融新闻中语义由分散线索共同构成的上下文复杂性。 https://hub.opencompass.org.cn/da…

作者头像 李华
网站建设 2026/3/27 0:59:39

AI+教育创新:Z-Image-Turbo在教学场景中的快速部署

AI教育创新&#xff1a;Z-Image-Turbo在教学场景中的快速部署 作为一名教育科技创业者&#xff0c;你是否想过将AI图像生成技术融入在线课程&#xff1f;无论是自动生成教学插图、创建个性化学习素材&#xff0c;还是让学生通过文字描述快速可视化知识点&#xff0c;Z-Image-Tu…

作者头像 李华
网站建设 2026/3/26 21:15:50

AI生成内容合规指南:基于Z-Image-Turbo云端环境的审核系统

AI生成内容合规指南&#xff1a;基于Z-Image-Turbo云端环境的审核系统 为什么需要AI生成内容审核系统&#xff1f; 随着AI图像生成技术的普及&#xff0c;越来越多的内容平台开始引入AI生成图像。但随之而来的合规风险也不容忽视&#xff1a;不当内容、版权问题、敏感信息等都可…

作者头像 李华
网站建设 2026/3/23 19:23:00

录制下载而不是收藏资料的原因

以视频为例&#xff0c;图片来源网络&#xff0c;直接上图&#xff1a;使用场景&#xff1a;1.喜欢的资料2.会过期的资料3.其他资料保存方法&#xff1a;录屏➕剪辑➕压缩➕存储

作者头像 李华
网站建设 2026/3/23 22:20:24

小白别踩坑:async-await真能保证顺序执行?搞懂调用时机才不翻

小白别踩坑&#xff1a;async-await真能保证顺序执行&#xff1f;搞懂调用时机才不翻 小白别踩坑&#xff1a;async-await真能保证顺序执行&#xff1f;搞懂调用时机才不翻车&#xff01;先整点废话——“我明明写了 await&#xff0c;怎么还是乱&#xff1f;”async 函数到底返…

作者头像 李华