#include<cstdio>
using namespace std;
const int N=2333333,MAX=0x3f3f3f3f,MIN=(-1)*MAX;
int n,a,minn=MAX,dire=1;
long long int ans=MIN;
int main() {
scanf("%d",&n);
for(int i=1; i<=n; ++i) {
scanf("%d",&a);//顺序保证不会先把自己更新(即不会输出错误的0)
if(dire<i&&ans<a-minn) ans=a-minn;//取相减最大值
if(a<minn) minn=a,dire=i;//记录位置,保证 j < i
}
printf("%lld",ans);
return 0;
}
为什么会错呢?