洛谷P3817题解:贪心算法解决糖果分配问题

一、问题分析

题目描述了一个有n盒糖果的序列,每盒有a[i]颗糖果。要求相邻两盒糖果的总和不能超过x,需要通过吃掉最少数量的糖果来满足这个条件。

二、解题思路

  1. 贪心算法‌:每次处理相邻两盒糖果时,优先处理后面的盒子,因为这样可以影响下一对相邻盒子的计算

  2. ‌局部最优‌:对于每对相邻盒子,计算超出x的部分,优先从后一盒吃掉糖果

  3. ‌全局最优‌:通过局部最优的选择,最终达到全局最优解(吃掉最少糖果)

三、关键算法详解

1. 输入处理
复制代码
int n, x;
cin >> n >> x;vector<int> a(n);for (int i = 0; i < n; ++i) {
    cin >> a[i];
}

读取糖果盒数量和限制值x,然后读取每盒糖果的数量。

2. 贪心处理相邻盒子
复制代码
for (int i = 1; i < n; ++i) {    if (a[i-1] + a[i] > x) {        int need_to_eat = a[i-1] + a[i] - x;        int can_eat = min(need_to_eat, a[i]);
        a[i] -= can_eat;        if (can_eat < need_to_eat) {
            a[i-1] -= (need_to_eat - can_eat);
        }
        total_eaten += need_to_eat;
    }
}

核心贪心逻辑:对于每对相邻盒子,计算超出部分,优先从后一盒吃掉糖果,如果还不够再吃前一盒的。

四、完整代码

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main() {
    int n, x;
    cin >> n >> x;
    
    vector<int> a(n);
    for (int i = 0; i < n; ++i) {
        cin >> a[i];
    }
    
    long long total_eaten = 0;
    
    // 从左到右处理相邻盒子
    for (int i = 1; i < n; ++i) {
        if (a[i-1] + a[i] > x) {
            // 计算需要吃掉的糖果数
            int need_to_eat = a[i-1] + a[i] - x;
            // 优先吃当前盒子的糖果,因为可以影响下一对
            int can_eat = min(need_to_eat, a[i]);
            a[i] -= can_eat;
            // 如果还不够,再吃前一个盒子的
            if (can_eat < need_to_eat) {
                a[i-1] -= (need_to_eat - can_eat);
            }
            total_eaten += need_to_eat;
        }
    }
    
    cout << total_eaten << endl;
    return 0;
}

来源:洛谷P3817题解:贪心算法解决糖果分配问题

相关推荐
_OP_CHEN2 分钟前
【算法基础篇】(三十七)图论基础之多源最短路:Floyd 算法吃透所有点对最短路径!
算法·蓝桥杯·图论·算法竞赛·floyd算法·acm/icpc·多源最短路
Web极客码2 分钟前
如何选择最适合的内容管理系统(CMS)?
java·数据库·算法
wangnaisheng9 分钟前
彩虹编码映射实现:C++与C#
c++·c#
程序员三明治9 分钟前
【动态规划】01背包与完全背包问题详解,LeetCode零钱兑换II秒解,轻松解力扣
算法·leetcode·动态规划·java后端·01背包·完全背包·零钱兑换
waves浪游11 分钟前
进程控制(下)
linux·运维·服务器·开发语言·c++
自由生长202411 分钟前
大数据计算框架-流式计算的Join
算法
IT猿手11 分钟前
融合DWA的青蒿素优化算法(Artemisinin Optimization Algorithm, AOA)求解无人机三维动态避障路径规划,MATLAB代码
算法·matlab·无人机
H_z___14 分钟前
Codeforces Global Round 31 (Div. 1 + Div. 2) A ~ E
数据结构·算法
兵哥工控15 分钟前
mfc两个线程的创建、启动、安全结束实例
c++·mfc·多线程·线程安全退出
小龙报16 分钟前
【算法通关指南:算法基础篇 】双指针专题:1.唯一的雪花 2.逛画展 3.字符串 4.丢手绢
c语言·数据结构·c++·人工智能·深度学习·算法·信息与通信