2025 年 06 月 三级真题(1)--分糖果

【题目】

【解题思路】

本题的难点是理解题意,每个小朋友需要的糖果数量是已知的(直接输入),现在按照题目要求,每个小朋友实际拿到的糖果数量应该是满足两点:一是满足他自己实际需要;二是满足比前一个小朋友的糖果数量多。所以可以先将实际需要的糖果数量依次存入数组中,再对组数的相邻的两个数进行比较,如果当前的数值小于或等于前一个数值,则更新当前数值为前一个数值+1,否则不变,经过n-1(第一个小朋友前面没有数值,所以不需要比较)次比较后,数组中存储的是每个小朋友实际的得到的糖果数量。最后再用循环累加求和即可。

【代码】

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
  int n;
  cin>>n;
  int a[n];
  for(int i=0;i<n;i++)//输入每个小朋友至少学需要分到的糖果数量
    cin>>a[i];
  for(int i=1;i<n;i++)//根据题目要求,如果当前的小朋友需要的糖果数量比前一个小朋友的数量少,则更新当前小朋友的糖果数量为前一个小朋友的数量+1
    if(a[i]<=a[i-1])
      a[i]=a[i-1]+1;
  int sum=0;
  for(int i=0;i<n;i++)//对实际小朋友需要分到的糖果数量累加求和
     sum+=a[i];
  cout<<sum;   
  return 0;
}
相关推荐
Fcy6481 天前
算法基础详解(二)枚举算法——普通枚举与二进制枚举
算法·枚举算法
承渊政道1 天前
【优选算法】(实战:栈、队列、优先级队列高频考题通关全解)
数据结构·c++·笔记·学习·算法·leetcode·宽度优先
py有趣1 天前
力扣热门100题之将有序数组转为二叉搜索树
算法·leetcode
天若有情6731 天前
Python精神折磨系列(完整11集·无断层版)
数据库·python·算法
凌波粒1 天前
LeetCode--383.赎金信(哈希表)
java·算法·leetcode·散列表
liulilittle1 天前
OPENPPP2 1.0.0.26145 正式版发布:内核态 SYSNAT 性能飞跃 + Windows 平台避坑指南
开发语言·网络·c++·windows·通信·vrrp
AIminminHu1 天前
OpenGL渲染与几何内核那点事-项目实践理论补充(三-1-(2):当你的CAD代码变得“又大又乱”:从手动编译到CMake,从随性编码到单元测试))
c++·单元测试·cmake·cad·cad开发
xiaoye-duck1 天前
《算法题讲解指南:动态规划算法--子数组系列》--23.等差数列划分,24.最长湍流子数组
c++·算法·动态规划
消失的旧时光-19431 天前
C++ 网络服务端主线:从线程池到 Reactor 的完整路线图
开发语言·网络·c++·线程池·并发
小O的算法实验室1 天前
2026年SEVC,高密度仓库中结合任务分配的多AGV无冲突调度框架,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进