NYOJ71 独木舟上的旅行

独木舟上的旅行

时间限制: 3000 ms  |  内存限制: 65535 KB
难度: 2
描述

进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别。一条独木舟最多只能乘坐两个人,且乘客的总重量不能超过独木舟的最大承载量。我们要尽量减少这次活动中的花销,所以要找出可以安置所有旅客的最少的独木舟条数。现在请写一个程序,读入独木舟的最大承载量、旅客数目和每位旅客的重量。根据给出的规则,计算要安置所有旅客必须的最少的独木舟条数,并输出结果。

输入
第一行输入s,表示测试数据的组数;
每组数据的第一行包括两个整数w,n,80<=w<=200,1<=n<=300,w为一条独木舟的最大承载量,n为人数;
接下来的一组数据为每个人的重量(不能大于船的承载量);
输出
每组人数所需要的最少独木舟的条数。
样例输入
385 65 84 85 80 84 8390 390 45 60100 550 50 90 40 60
样例输出
533

/*重点在此题说的每条船最多俩个人!!!
贪心。先排序,然后最重和最轻相加,大于最大重量计数说明此次最轻的还可以匹配,所以将下标变上次的,进行下一次的相加,如果小于或等于最大重量,将最大重量排除,然后计数,即可
*/
#include <stdio.h>
#include <stdlib.h>
int cmp(const void *a,const void *b)
{
    return (*(int*)a - *(int*)b);
}
int main()
{
    int i,text_n,weight,people,a[301],count;
    scanf("%d",&text_n);
    while(text_n--)
    {
        count = 0;
        scanf("%d%d",&weight,&people);
        for(i=0;i<people;i++)
        {
            scanf("%d",&a[i]);
        }
        qsort(a,people,sizeof(a[0]),cmp);
        /*for(i=0;i<people;i++)
        {
            printf("%d ",a[i]);
        }*/
        for(i=0;i<people;i++)
        {
           if(a[i] + a[people -1] > weight)
           {
               count++;
               people--;//最重的人已上船
               i--;//最轻的人还可以和其他人匹配,所以退回来
           }
           else
           {
               count++;
               people--;//同上
           }
        }

        printf("%d\n",count);
    }
    return 0;
}


你可能感兴趣的:(NYOJ71 独木舟上的旅行)