【NYOJ】[47]过河问题
2016-07-22 16:09
225 查看
分析可知(从小到大排序后)
过桥比较省时间的方法有两种
1、a[0] a[1]先过a[0]回
a
a[n-1]过 a[1]回
则总时间a[1]+a[0]+a
+a[1]
2、a[0]带a
过a[0]回
a[0]带a[n-1]过a[0]回
则总时间a
+a[0]+a[n-1]+a[0]
区别在与a[1]+a[1]与a[n-1]+a[0]
两者应该去更小的那一种方法
所以可以两两考虑
把最大的两个送过桥
当最后三人以下时
剩三人
则a[0]带a[2]过a[0]回
a[0]与a[1]过
总时间 a[2]+a[0]+a[1]
剩两人
a[0]与a[1]过
总时间a[1]
剩1人(说明总人数只有一人)
总时间a[0]
#include<stdio.h> #include<algorithm> using namespace std; int a[1200]; int main() { int T; scanf("%d",&T); while(T--) { int n; scanf("%d",&n); for(int i=0; i<n; i++) scanf("%d",&a[i]); sort(a,a+n); int sum=0; int i; for(i=n-1; i>2; i-=2) { sum+=min(a[1]+a[0]+a[i]+a[1],a[i]+a[0]+a[i-1]+a[0]); } if(i==2) printf("%d\n",sum+a[0]+a[1]+a[2]); else if(i==1) printf("%d\n",sum+a[1]); else printf("%d\n",sum+a[0]); } return 0; }
题目地址:【NYOJ】[47]过河问题
相关文章推荐
- 1.一些 贪心算法 的简单思维题:
- 贪心算法——字典序最小问题
- 贪心算法——区间调度问题
- Jump Game I,II 贪心
- Wildcard Matching
- 贪心法实现无向图的划分 代码
- 贪心题目循环和控制台折行
- HDOJ 1009
- 【解题报告】【USACO】酸奶工厂
- 【解题报告】【】交谊舞
- POJ 1328
- Best Cow Line
- HDU 1009 Fatmouse's Trade
- POJ2377 Bad Cowtractors
- 贪心 hdu 1003
- 最大容器
- 满足和为定值的两个数或多个数
- Codeforces Round #300
- HUD1052 __ P2 1002 __ Tian Ji -- The Horse Racing
- 2015年国家集训队测试 BZOJ3816矩阵变幻