码迷,mamicode.com
首页 > 其他好文 > 详细

[编程题] 疯狂队列 网易2018

时间:2017-09-24 16:14:14      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:algorithm   老师   style   out   while   网易   排序   题目   输出   

小易老师是非常严厉的,它会要求所有学生在进入教室前都排成一列,并且他要求学生按照身高不递减的顺序排列。有一次,n个学生在列队的时候,小易老师正好去卫生间了。学生们终于有机会反击了,于是学生们决定来一次疯狂的队列,他们定义一个队列的疯狂值为每对相邻排列学生身高差的绝对值总和。由于按照身高顺序排列的队列的疯狂值是最小的,他们当然决定按照疯狂值最大的顺序来进行列队。现在给出n个学生的身高,请计算出这些学生列队的最大可能的疯狂值。小易老师回来一定会气得半死。 

输入描述:
输入包括两行,第一行一个整数n(1 ≤ n ≤ 50),表示学生的人数
第二行为n个整数h[i](1 ≤ h[i] ≤ 1000),表示每个学生的身高



输出描述:
输出一个整数,表示n个学生列队可以获得的最大的疯狂值。

如样例所示: 
当队列排列顺序是: 25-10-40-5-25, 身高差绝对值的总和为15+30+35+20=100。
这是最大的疯狂值了。

 

输入例子1:
5
5 10 25 40 25

 

输出例子1:
100

解析:该题目放的规律比较明显,要想获得最大的疯狂值,先给数组排序,然后把最大的放中间,两边放最小的,然后两边放次大的,然后两边再放次小的

#include<iostream>
#include<deque>
#include<algorithm>
using namespace std;
int main()
{
    int n;
    cin>>n;
    
    int a[50];
    for(int i=0;i<n;i++)
    {
        cin>>a[i];
    }
    sort(a,a+n);
    
    deque<int> d;
    int l=0,r=n-1;
    d.push_front(a[r]);
    r--;
    while(l<=r)
    {
         if(l<=r)
         {
             d.push_front(a[l++]);
             if(l<=r)
             d.push_back(a[l++]);
         }
         if(l<=r)
         {
              d.push_front(a[r--]);
              if(l<=r)
              d.push_back(a[r--]);
         }
    }
    if(abs(d[n-1]-d[n-2])<abs(d[n-1]-d[0])){
            d.push_front(d.back());
            d.pop_back();
        }
        int res=0;
        for(int i=1;i<n;i++){
            res+=abs(d[i]-d[i-1]);
        }
        cout<<res<<endl;
}

 

[编程题] 疯狂队列 网易2018

标签:algorithm   老师   style   out   while   网易   排序   题目   输出   

原文地址:http://www.cnblogs.com/zdy1996/p/7587257.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!