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);} }?
轉載于:https://www.cnblogs.com/ToTOrz/p/6159579.html
總結
以上是生活随笔為你收集整理的XidianOJ 1176 ship的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 互联网公司前端初级Javascript面
- 下一篇: 20145203 《信息安全系统设计基础