独木舟上的旅行

题目                                                             

  

独木舟上的旅行

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

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

输入
第一行输入s,表示测试数据的组数;
每组数据的第一行包括两个整数w,n,80<=w<=200,1<=n<=300,w为一条独木舟的最大承载量,n为人数;
接下来的一组数据为每个人的重量(不能大于船的承载量);
输出
每组人数所需要的最少独木舟的条数。
样例输入
3
85 6
5 84 85 80 84 83
90 3
90 45 60
100 5
50 50 90 40 60
样例输出
5
3
3
上传者
李剑锋

想法:
我当时想应该就像背包问题一样,先从大到小排序,然后依次放入独木舟,放入独木舟后空间为w=w-a[i],需要注意独木舟上最多两个人,为了做到已经进入独木舟的人不会重复计算,将a[i]赋值为比最大载重大的数,如a[i]=f+1。


代码<C语言>
 #include<stdio.h>
int main()
{
   int s,w,n,a[305],i,j,f,g,k,t,count=0,sum;
   scanf("%d",&s);//输入要测试的次数
   while(s--){
        scanf("%d%d",&w,&n);//输入独木舟的最大承载重量和人数
        f=w;//方便下面还原w
        for(i=0;i<n;i++)
        {
             scanf("%d",&a[i]);//输入人的重量
        }
//选择法排序(从大到小)
    for(i=0;i<n-1;i++)
   {
      k=i;
      for(j=i+1;j<n;j++)
     {
         if(a[j]>a[k])//找出最大数的下标
         {
            k=j;//标记位置
         }
      }
      if(k!=i)//若最大数的下标位置不在下标位置i,则交换
     {
        t=a[k];
a[k]=a[i];
a[i]=t;
     }
 }
//求独木舟的数量
do{
        sum=0;
        g=0;
        for(i=0;i<n&&w>0;i++)
       {
          if(a[i]<=w)
          {
           w=w-a[i];//计算剩余空间
           a[i]=f+1;//为避免重复计算
           g++;
           }
          if(g==2)//一条独木舟上最多两个人
           break;
        }
       w=f;//还原w
       count++;//记录独木舟的条数
//求当前数组的和
    for(i=0;i<n;i++)
    {
        sum=sum+a[i];
    }
  }while(sum!=n*(f+1));//当数组全部替换的时候,说明游客都已坐入独木舟,退出循环
   printf("%d\n",count);
   count=0;//运算第二组之前,初始化独木舟数量
}
 return 0;
}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值