Atcoder 2152 Boxes and Candies(模拟 + 水题)

该博客介绍了Atcoder上的题目C - Boxes and Candies,要求在满足相邻两个盒子糖果数量差不超过x的情况下,找出最少需要吃掉多少糖果。通过遍历并调整每个盒子的糖果数,可以找到解题策略。提供了样例输入和输出,以及简单的解题代码。

题目链接:http://abc048.contest.atcoder.jp/tasks/arc064_a?lang=en


C - Boxes and Candies


Time limit : 2sec / Memory limit : 256MB

Score : 300 points

Problem Statement

There are N boxes arranged in a row. Initially, the i-th box from the left contains ai candies.

Snuke can perform the following operation any number of times:

  • Choose a box containing at least one candy, and eat one of the candies in the chosen box.

His objective is as follows:

  • Any two neighboring boxes contain at most x candies in total.

Find the minimum number of operations required to achieve the objective.

Constraints

  • 2N105
  • 0ai109
  • 0x109

Input

The input is given from Standard Input in the following format:

N x
a1 a2  aN

Output

Print the minimum number of operations required to achieve the objective.


Sample Input 1

Copy
3 3
2 2 2

Sample Output 1

Copy
1

Eat one candy in the second box. Then, the number of candies in each box becomes (2,1,2).


Sample Input 2

Copy
6 1
1 6 1 2 0 4

Sample Output 2

Copy
11

For example, eat six candies in the second box, two in the fourth box, and three in the sixth box. Then, the number of candies in each box becomes (1,0,1,0,0,1).


Sample Input 3

Copy
5 9
3 1 4 1 5

Sample Output 3

Copy
0

The objective is already achieved without performing operations.


Sample Input 4

Copy
2 0
5 5

Sample Output 4

Copy
10

All the candies need to be eaten.


Submit



题意:n个盒子,每个盒子里面都有a[i]个糖果,要求每个两个盒子糖果差不能超过x,问至少要吃去几个糖果

解析:遍历一遍就可以了,一直吃右侧盒子里的糖果


代码:

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
#include<map>
#include<cmath>
#define N 100009
using namespace std;
const int INF = 0x3f3f3f3f;
int a[N];

int main()
{
    int n, x;
    scanf("%d%d", &n, &x);
    for(int i = 1; i <= n; i++) scanf("%d", &a[i]);
    long long ans, now; ans = now = 0;
    for(int i = 1; i <= n; i++)
    {
        if(now + a[i] <= x) now = a[i];
        else ans += now + a[i] - x, now = a[i] - (now + a[i] - x);
    }
    printf("%lld\n", ans);
    return 0;
}



评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值