独木舟上的旅行

讲述了魔法学院的学生们如何通过合理配对乘坐有限数量船只的问题,采用贪心算法进行解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

魔法学院放暑假了,WC和他的一帮魔友一起去弗尔夫斯基山脉玩。莫伊拉同学突然想划船到对岸找被削的Mercy玩,这里的每一艘船都是同一型号,能承受的重量都是一样的,并且每艘船都可以坐一个或者两个人。WC他们共有n个人,现在我们知道他们每个人的质量,而且每个人体重也不超过船的承重。可惜经费有限,他们必须租尽可能少的船,请问他们最少要租几艘船? 

Input

第一行包含两个正整数n 和m ,n<=10^4,m<=2*10^9,表示人的数量和船的最大承重。 接下来n行,每行一个正整数,表示每个人的体重。体重不超过m。 

Output

一行一个整数表示最少需要的独木舟数。

Sample Input

3 6
1
2
3

Sample Output

2
#include<stdio.h>
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
	int s;
		int w,n,i,j,c;
		int a[300];
		scanf("%d %d",&n,&w);
		for(i=0;i<n;i++)scanf("%d",&a[i]);
		sort(a,a+n);            //sort,默认自小到达排序。
		j=0;
		c=0;
		for(i=n-1;i>=j;i--)   //1.本题需要最大的与最小的结合,否则相对比较大的只能自己一艘,
		{
			if(a[i]+a[j]<=w)  //2.最大的结合最小的,这样就可能节省一艘船,            	
				j++;          //3.如果满足条件,次大与次小结合,.......
				c++;           //这样求出来便是最节省的。
		}printf("%d\n",c);

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值