题目
独木舟上的旅行
时间限制:
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;
}
独木舟上的旅行
时间限制:
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;
}