装载问题(load)

问题描述:

有一批共n 个集装箱要装上艘载重量为c 的轮船,其中集装箱i 的重量为wi。找出一种最

优装载方案,将轮船尽可能装满,即在装载体积不受限制的情况下,将尽可能重的集装箱装

上轮船。

输入格式:

第一行有2 个正整数n(1<=n<=40)和c。n 是集装箱数,c 是轮船的载重量。接下来的1 个有

n 个正整数,表示集装箱重量。

输出格式:

输出最大装载量

输入样例:

5 10

7 2 6 5 4

输出样例:

  1. 10

****

 #include<iostream>

 #include<cstdlib>

 using namespace std;

 int n,c,a[],i,m=;

 bool f[];

 void fa(int s,int t)

 {

          int i;

          if (s==c){cout<<s<<endl;exit();} //如果和要求的载重量相同那么一定是最优解

          if (s>c) {return;}    //如果已放的重量超载那就回溯剪掉这次的重新加

          if (s>m)m=s;  //m表示最大重量如果新方法可使重量大于原先的重量那么更新最大重量

          //if (t>n){cout<<m<<endl;exit(0);}

          for (i=;i<=n;i++)  //循环每一个物体

            if (f[i])  //如果这个物体没有被放

            {

                 f[i]=false;   //那么放这个物体并且把这个物体标记为已放

                 s+=a[i];  //重量更新

                 fa(s,t+);  //再次判断这个物体是否还可以再加 变的更大

                 s-=a[i];   //如果不能剪掉这一次然后重新加,并且把这个物体放回去标记为待放

                 f[i]=true;

            }

 }

 int main()

 {

          cin>>n>>c;

          for (i=;i<=n;++i)cin>>a[i];

          for (i=;i<=n;++i)f[i]=true;   //表示物体待放

          fa(,);      //s表示已放的重量

         cout<<m<<endl;

          return ;

 }

先把所有物体设为待放,然后一个一个使满足要求就继续并且更新最大值,不满足要求返回重新加。

***一开始的时候我是循环从i个数加到第j个数字,若加上去的数离c更近就保存这个数,如果比c大就变回加之前的数最后把保存下来的最大值输出。样例是过了。可能是面对其他的数据会有遗漏的可能性吧。

05-11 20:22