XidianOJ 1176 ship

Posted TOTOTOTOTZZZZZ

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了XidianOJ 1176 ship相关的知识,希望对你有一定的参考价值。

题目描述

The members of XDU-ACM group went camp this summer holiday. They came across a river one day. There was a ship which only can carry at most two people at the same time. The ship would move only if there is at least one person in the ship to drive it. Everyone had different cost of time to pass the river, and the time of pass the river by ship depended on the longer time of the two passengers. You should tell them the minimum total time that all of the members should spend to arrive the next band.

输入

The input contains multiple test cases.
The first line of each case contains one integer n (1≤n≤100000). Then next n lines contains n positive integers a[i](1≤a[i]≤10000)-the ith person spend a[i] time to pass the river.

输出

For each case ,print the minimum total time they should spend in the only line.

--正文

首先按时间长短排好,则a[1]是最快的,a[2]次快,a[n]最慢,a[n-1]次慢

  若 (2*a[2]+a[1]+a[n] > 2*a[1]+a[n-1]+a[n])

  则每次先a[1],a[n]坐船,a[1]回来和a[n-1]坐,a[1]回来

  否则就每次a[1],a[2]坐船,a[1]回来,a[n-1]和a[n]坐,a[2]回来

  这样每次都少掉2个人,直到n<4为止

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;

int n;
int a[100001];
long long res = 0;

void solve(int n){
    if (n <= 3){
        if (n == 3){
            res += a[1] + a[2] + a[3];
            return;
        }
        if (n == 2){
            res += a[2];
            return;
        }
        if (n == 1){
            res += a[1];
            return;
        }
    }
    res += min(2*a[2]+a[1]+a[n],2*a[1]+a[n-1]+a[n]);
    solve(n-2);
}

int main(){
    while (scanf("%d",&n) != EOF){
        int i;
        res = 0;
        for (i=1;i<=n;i++){
            scanf("%d",&a[i]);
        }
        sort(a+1,a+1+n);
//        for (i=1;i<=n;i++){
//            printf("%d ",a[i]);
//        }
        solve(n);
        printf("%lld\n",res);
    }
} 

 

以上是关于XidianOJ 1176 ship的主要内容,如果未能解决你的问题,请参考以下文章

XidianOJ 1140 寻找万神

XidianOJ 1000 a+b

XidianOJ 1073 Nunchakus

HDU 1176 免费馅饼

XidianOJ 1120 Gold of Orz Pandas

[HDU1176]免费馅饼(DP)