输入
第一行有一个数字n
第二行有n个数字ai,每个整数之间有一个空格。
第三行有个数字m,是游戏参与者要求恰当插入至a1、a2……ai之间位置的一个数。
输出
一个数字,表明“左营能量”和“右营能量”的最小差。
样例输入 复制
4
1 5 3 4
2
样例输出 复制
1
提示
70%数据1<=n<=10000,1<=ai<=10000,m<=10000;
100%数据,1<=n<=100000,0<=ai<=1000000,0<=m<=10000000。
#include <bits/stdc++.h>
#define ll long long
using namespace std;
ll n,mi,i,a[1000100],f[1000100],a1,a2,m;
main(){
cin>>n;mi=2e9;
for(i=1;i<=n;i++)cin>>a[i],f[i]=f[i-1]+a[i];
cin>>m;
for(i=1;i<=n;i++){
a1=f[i]+m;a2=f[n]-f[i];
mi=min(mi,abs(a1-a2));
}
cout<<mi;
}
#include <bits/stdc++.h>
#define ll long long
using namespace std;
ll n,mi,i,a[1000100],f[1000100],a1,a2,m;
main(){
cin>>n;mi=2e9;
for(i=1;i<=n;i++)cin>>a[i],f[i]=f[i-1]+a[i];
cin>>m;
for(i=1;i<=n;i++){
a1=f[i]+m;a2=f[n]-f[i];
mi=min(mi,abs(a1-a2));
}
cout<<mi;
}