南阳 71 独木舟上的旅行
2014-01-15 10:51
274 查看
思路:
每条船最多只能乘坐两个人,结合一些常识我们很容易想到解决思路:每条船上安排一个体重大的和体重小的。
有了思路后,方法就简单了,先安排一个体重大的上船,如果此船还能承下体重较小的乘客时,则两人一条船,否则此船只能承载一个人。
另外,为使寻找体重大的和体重小的乘客,需要先按体重从大到小排序。这样只需从数组两头向中间遍历一遍即可。
每条船最多只能乘坐两个人,结合一些常识我们很容易想到解决思路:每条船上安排一个体重大的和体重小的。
有了思路后,方法就简单了,先安排一个体重大的上船,如果此船还能承下体重较小的乘客时,则两人一条船,否则此船只能承载一个人。
另外,为使寻找体重大的和体重小的乘客,需要先按体重从大到小排序。这样只需从数组两头向中间遍历一遍即可。
#include<stdio.h> #include<string.h> #include<stdlib.h> int cmp(const void *a,const void *b) { return *(int *)a-*(int *)b; } int main() { int n,m,t,i,j,s; int a[330]; scanf("%d",&n); while(n--) { memset(a,0,sizeof(a)); scanf("%d%d",&m,&t); for(i=0;i<t;i++) scanf("%d",&a[i]); qsort(a,t,sizeof(a[0]),cmp); s=0;j=t-1; for(i=0;i<=j;) if(a[i]+a[j]>m) {j--;s++;}//++;}//如果后面没有和前面元素相匹的元素,则船数加1,同时下标减1,看下一个元素; else {i++;j--;s++;}//如果后面的元素和该元素相加后小于等于船的容量的,若有则船数加1,同时下标一个加1,一个减1,船加1 printf("%d\n",s); } return 0; }
相关文章推荐
- 南阳题目71-独木舟上的旅行
- 南阳oj NYOj 贪心 题目71 独木舟上的旅行
- 南阳ACM 题目71:独木舟上的旅行 Java版
- 南阳oj 71 独木舟上的旅行
- 独木舟上的旅行(南阳oj71)(贪心)
- 南阳71 独木舟上的旅行
- NYOJ71 独木舟上的旅行
- 【NYOJ-71】 独木舟上的旅行
- nyoj 71 独木舟上的旅行
- C语言 南阳理工 ACM 71 独木舟上的旅行
- NYOJ 71 独木舟上的旅行
- nyoj 71 独木舟上的旅行
- nyoj 71 独木舟上的旅行
- nyoj 71 独木舟上的旅行【贪心】
- 题目71 独木舟上的旅行
- nyoj 题目71:独木舟上的旅行 贪心算法
- 南理 71 独木舟上的旅行
- nyoj_71_独木舟上的旅行_201312122051
- NYOJ-71 独木舟上的旅行
- NYOJ71独木舟上的旅行