网易编程题:疯狂队列(序列相邻元素之差的绝对值和最大)

#include <bits/stdc++.h>

#include <unistd.h>

using namespace std;

int func(vector<int> &height){

int n = height.size();

sort(height.begin(),height.end(),less<int>());

int lastMax = height[n-1];

int lastMin = height[0];

int sum =  lastMax - lastMin;

int curMinIndex = 1,curMaxIndex = n - 2;

/*每次从数组中选取最大最小元素和新序列中最大最小元素交错做差*/

while(curMinIndex < curMaxIndex){

sum += lastMax - height[curMinIndex];

sum += height[curMaxIndex] - lastMin;

lastMin = height[curMinIndex];

lastMax = height[curMaxIndex];

++curMinIndex;

--curMaxIndex;

}

/*如果有奇数个元素,最后curMinIndex = curMaxIndex*/

if(curMinIndex == curMaxIndex){

sum = max(sum + abs(height[curMinIndex] - lastMin),sum + abs(height[curMaxIndex] - lastMax));

}

return  sum;

}

int main(){

int n;

while(cin >> n){

vector<int> height(n);

for(auto i = 0;i < n;++i)

cin>>height[i];

cout<<func(height)<<endl;

}

    return 0;

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容