您的位置:首页 > 大数据 > 人工智能

给一个数组[a1,a2,a3....an],要求出令ai-aj有最大值,其中i<=j,时间和空间复杂度尽可能小

2013-09-28 20:54 2421 查看
给一个数组[a1,a2,a3....an],要求出令ai-aj有最大值,其中i<=j,要求时间和空间复杂度尽可能小,数组无序
int m = a[0], max_diff = 0;
for (int i = 1; i < n; ++i) {
if (m - a[i] > max_diff)
max_diff = m - a[i];
m = max(m, a[i]);
}
return max_diff;
//如果要求ai-aj绝对值最大的话,就用一个min记录最小值
int ma = a[0], min = a[0], max_diff = 0;
for(int i=1; i<n; i++){
if(ma - min > max_diff)
max_diff = max - min;
ma = max(ma, a[i]);
min = min(min, a[i]);
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐