当前位置: 首页 > news >正文

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
http://www.jsqmd.com/news/216843/

相关文章:

  • Lenovo在2026年国际消费电子展Lenovo全球创新科技大会上发布个性化、感知型和主动式AI产品组合,定义混合AI新时代
  • 10分钟搭建阿里通义Z-Image-Turbo WebUI:科哥二次开发镜像一键部署指南
  • ClickHouse 分片集群备份一致性分析文档
  • NPP 北方森林:美国苏必利尔国家森林,1983-1984 年,R1
  • 材料中心物流信息管理系统的设计与实现
  • 架构演进过程
  • 每日 AI 评测速递来啦(1.8)
  • 基于微信小程序的点餐小程序开发与设计
  • 金融级数据治理+企业级架构管控:五度易链的数据治理方案与技术路径
  • K8s资源管理与项目生命周期
  • 2026 国自然申请书大改,不变的是对内容质量的高要求
  • 区间取反与区间数一【牛客tracker 每日一题】
  • 基于PyTorch的CBOW模型实现与词向量生成
  • 基于大数据的颈椎病预防交流与数据可视化分析平台设计与实现
  • 【力扣hot100题】合并区间(9)
  • DeepBI 帮亚马逊卖家突破销售瓶颈,暴增近20倍销量!
  • 交互式教学:将阿里通义Z-Image-Turbo集成到Jupyter Notebook的秘诀
  • 连锁店管理力不从心?让智能体接管30%重复工作
  • 模型压缩魔法:让Z-Image-Turbo在消费级GPU上流畅运行
  • AI+教育创新:Z-Image-Turbo在教学场景中的快速部署
  • 一份精美的Excel,究竟需要多久?
  • ACPI!PciConfigSpaceHandlerWorker函数中的hal!HalGetBusDataByOffset----重要
  • 【亚太杯数学建模一等奖又又拿下】
  • AI生成内容版权探索:Z-Image-Turbo云端环境下的水印集成
  • Z-Image-Turbo多租户方案:云端环境下的资源共享与隔离
  • 揭秘Z-Image-Turbo:如何用阿里云镜像1小时搭建高性能AI画室
  • 图书管理系统的设计与实现
  • 从DALL·E到Z-Image-Turbo:低成本替代方案的快速迁移
  • 头部企业如何借AI HR破局2026人才战略新棋局
  • 假期休闲不重样,靠谱短剧天天有新剧