题目描述小 A 有 n 个糖果盒第 i 个盒中有 ai 颗糖果。小 A 每次可以从其中一盒糖果中吃掉一颗他想知道要让任意两个相邻的盒子中糖的个数之和都不大于 x至少得吃掉几颗糖。输入格式输入的第一行是两个用空格隔开的整数代表糖果盒的个数 n 和给定的参数 x。第二行有 n 个用空格隔开的整数第 i 个整数代表第 i 盒糖的糖果个数 ai。输出格式输出一行一个整数代表最少要吃掉的糖果的数量。输入输出样例输入 #1复制3 3 2 2 2输出 #1复制1输入 #2复制6 1 1 6 1 2 0 4输出 #2复制11输入 #3复制5 9 3 1 4 1 5输出 #3复制0说明/提示样例输入输出 1 解释吃掉第 2 盒中的一个糖果即可。样例输入输出 2 解释第 2 盒糖吃掉 6 颗第 4 盒吃掉 2 颗第 6 盒吃掉 3 颗。数据规模与约定对于 30% 的数据保证 n≤20ai,x≤100。对于 70% 的数据保证 n≤103ai,x≤105。对于 100% 的数据保证 2≤n≤1050≤ai,x≤109。题解#include iostreamusing namespace std;#include algorithmlong long a[100005];int main(){int n;long long x;cinnx;for(int i0;in;i){cina[i];}long long sum0;//统计需要吃的总数for(int i1;in;i){long long numa[i-1]a[i];if(numx){long long tempnum-x;//吃掉的数量//先吃后盒子long long t1min(a[i],temp);a[i]-t1;sumt1;//吃前面盒子long long t2temp-t1;a[i-1]-t2;sumt2;}}coutsumendl;system(pause);return 0;}
洛谷:P3817 小A的糖果
题目描述小 A 有 n 个糖果盒第 i 个盒中有 ai 颗糖果。小 A 每次可以从其中一盒糖果中吃掉一颗他想知道要让任意两个相邻的盒子中糖的个数之和都不大于 x至少得吃掉几颗糖。输入格式输入的第一行是两个用空格隔开的整数代表糖果盒的个数 n 和给定的参数 x。第二行有 n 个用空格隔开的整数第 i 个整数代表第 i 盒糖的糖果个数 ai。输出格式输出一行一个整数代表最少要吃掉的糖果的数量。输入输出样例输入 #1复制3 3 2 2 2输出 #1复制1输入 #2复制6 1 1 6 1 2 0 4输出 #2复制11输入 #3复制5 9 3 1 4 1 5输出 #3复制0说明/提示样例输入输出 1 解释吃掉第 2 盒中的一个糖果即可。样例输入输出 2 解释第 2 盒糖吃掉 6 颗第 4 盒吃掉 2 颗第 6 盒吃掉 3 颗。数据规模与约定对于 30% 的数据保证 n≤20ai,x≤100。对于 70% 的数据保证 n≤103ai,x≤105。对于 100% 的数据保证 2≤n≤1050≤ai,x≤109。题解#include iostreamusing namespace std;#include algorithmlong long a[100005];int main(){int n;long long x;cinnx;for(int i0;in;i){cina[i];}long long sum0;//统计需要吃的总数for(int i1;in;i){long long numa[i-1]a[i];if(numx){long long tempnum-x;//吃掉的数量//先吃后盒子long long t1min(a[i],temp);a[i]-t1;sumt1;//吃前面盒子long long t2temp-t1;a[i-1]-t2;sumt2;}}coutsumendl;system(pause);return 0;}