網(wǎng)易編程題:瘋狂隊(duì)列(序列相鄰元素之差的絕對(duì)值和最大)

#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;

/*每次從數(shù)組中選取最大最小元素和新序列中最大最小元素交錯(cuò)做差*/

while(curMinIndex < curMaxIndex){

sum += lastMax - height[curMinIndex];

sum += height[curMaxIndex] - lastMin;

lastMin = height[curMinIndex];

lastMax = height[curMaxIndex];

++curMinIndex;

--curMaxIndex;

}

/*如果有奇數(shù)個(gè)元素,最后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;

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容