c-sum=0(abc362)

题意:给一个数字n,还有一些区间,在区间内选取一个数字,使得所有数字相加等于0.

分析:先令所有数字为右区间,如果(最大的数字)小于0,那么永远都不可能变成0,如果(最小的数字)大于0,那么永远都不可能变成0,再从1遍历到n,判断数字是否要向左移动(向左移动了sum就会变小)

#include<bits/stdc++.h>

using namespace std;

typedef long long ll;

int main(){

int n;cin>>n;

ll l[n+10],r[n+10];

int a[n+10];

ll sum=0;

for(int i=1;i<=n;i++){

cin>>l[i]>>r[i];

sum+=r[i];

}

if(sum<0)cout<<"No"<<endl;

else{

for(int i=1;i<=n;i++){

if(sum>r[i]-l[i]){//如果sum-区间差还是无法等于0,直接让他取最小值

sum-=(r[i]-l[i]);

r[i]=l[i];

}

else if(sum==0)break;

else{//sum-区间内的一个数可以变成0

r[i]-=sum;

sum=0;

}

}

if(sum>0){

cout<<"No"<<endl;return 0;

}

cout<<"Yes"<<endl;

for(int i=1;i<=n;i++){

cout<<r[i]<<" ";

}

}

}

相关推荐
deng-c-f13 小时前
Linux C/C++ 学习日记(63):Redis(四):事务
linux·c语言·c++
好奇龙猫14 小时前
大学院-筆記試験練習:线性代数和数据结构(8)
数据结构·线性代数
DYS_房东的猫14 小时前
《 C++ 零基础入门教程》第8章:多线程与并发编程 —— 让程序“同时做多件事”
开发语言·c++·算法
REDcker14 小时前
AIGCJson 库介绍与使用指南
c++·json·aigc·c
小郭团队14 小时前
1_1_七段式SVPWM (传统算法反正切)算法理论与 MATLAB 实现详解
人工智能·stm32·嵌入式硬件·算法·dsp开发
setary030114 小时前
c++泛型编程之Typelists
开发语言·c++
翟天保Steven14 小时前
医学影像-CBCT图像重建FDK算法
算法·医学影像·图像重建
松涛和鸣14 小时前
DAY53 UART Serial Communication
c语言·单片机·嵌入式硬件·tcp/ip·51单片机
星诺算法备案14 小时前
《算法安全自评估报告》的填报与实操(附模板)
人工智能·算法·备案·算法备案