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

洛谷 B4413:[GESP202509 三级] 数组清零

【题目来源】
https://www.luogu.com.cn/problem/B4413

【题目描述】
小 A 有一个由 n 个非负整数构成的数组 a=[a1, a2, …, an]。他会对阵组 a 重复进行以下操作,直到数组 a 只包含 0。在一次操作中,小 A 会依次完成以下三个步骤:
(1)在数组 a 中找到最大的整数,记其下标为 k。如果有多个最大值,那么选择其中下标最大的。
(2)从数组 a 所有不为零的整数中找到最小的整数 aj。
(3)将第一步找出的 ak 减去 aj。
例如,数组 a=[2,3,4] 需要 7 次操作变成 [0,0,0]:
[2,3,4]→[2,3,2]→[2,1,2]→[2,1,1]→[1,1,1]→[1,1,0]→[1,0,0]→[0,0,0]
小 A 想知道,对于给定的数组 a,需要多少次操作才能使得 a 中的整数全部变成 0。可以证明,a 中整数必然可以在有限次操作后全部变成 0。你能帮他计算出答案吗?

【输入格式】
第一行,一个正整数 n,表示数组 a 的长度。
第二行,n 个非负整数 a1, a2, …, an,表示数组 a 中的整数。

【输出格式】
一行,一个正整数,表示 a 中整数全部变成 0 所需要的操作次数。​​​​​​​

【输入样例一】
3
2 3 4

【输出样例一】
7

【输入样例二】
5
1 3 2 2 5

【输出样例二】
13

【数据范围】
对于所有测试点,保证 1≤n≤100,0≤ai≤100。

【算法分析】
终止条件‌:当数组中的最大值变为 0 时,说明所有元素都已为 0。

【算法代码】

#include <bits/stdc++.h>
using namespace std;const int maxn=105;
int a[maxn];
int cnt;int main() {int n;cin>>n;for(int i=1; i<=n; i++) {cin>>a[i];}while(1) {int p=n; //max-value's positionfor(int i=1; i<=n; i++) {if(a[i]>=a[p]) p=i;}if(a[p]==0) break;int t=a[p]; //min-valuefor(int i=1; i<=n; i++) {if(a[i]!=0) t=min(t,a[i]);}a[p]-=t;cnt++;}cout<<cnt<<endl;return 0;
}/*
in:
5
1 3 2 2 5out:
13
*/





【参考文献】
https://www.luogu.com.cn/problem/solution/B4413
https://gesp.ccf.org.cn/101/attach/1703975921385504.pdf


 

http://www.jsqmd.com/news/44925/

相关文章:

  • MOSHELL (7) : 构建3G RNC端到端性能可观测性体系 - 指南
  • 中大型超市智能运营导购系统:AI 精准推送,滞销品库存加速 19%!
  • 雨水从黑云降临到了人间 果实脱落枝叶吸收于地面 时间流逝再也回不到从前 曾经珍藏回忆变成不可逆爱恋
  • 高州市胃癌手术专家选择指南:茂名陈医生专业医学背景+丰富临床经验+精湛手术技术!
  • c#构建日报
  • linux ftp 修改密码
  • linux ftp shell
  • 我讨厌 DP 和 COUNT 的100个理由(下)
  • 详细介绍:数组初阶(2)
  • Gemini 3 Pro入门教程:从零开始学会使用最新gemini-3-pro-preview API接入
  • 20232314 2025-2026-1 《网络与系统攻防技术》实验七实验报告
  • 高州市陈郁强副主任擅长做肠癌手术:口碑优秀+医术高超!
  • 102302156 李子贤 数据采集第三次作业
  • SHELL脚本的基础入门
  • roocode_kilocode对比
  • 工程成本管理软件新纪元:选软件看这三点!
  • 全国计算机等级考试——二级JAVA完整大题题库【五十三道】
  • 【C + +】unordered_set 和 unordered_map 的用法、区别、性能全解析 - 实践
  • Spring AI 代码分析(一)--工程结构
  • Spring Boot迅速集成MiniMax、CosyVoice实现文本转语音
  • Cursor接入飞书MCP
  • 完整教程:微信生态新机遇:视频号推客模式助力商家突围
  • linux framework
  • linux framebuffer
  • Spring AI 代码分析(二)--Model 领域
  • gdb实践((2510更新)
  • Mars项目与TensorFlow集成指南
  • win10/win11系统默认应用或文件打开方式重启后被自动重置的解决办法
  • 详细介绍:第八节_PySide6基本窗口控件_按钮类控件(QAbstractButton)
  • 哪里有免费的编程体验课?2025国内外优质平台与真实体验价值分析