算法期末考试题目+代码

【问题描述】

求解乘船问题。有 n 个人,第 i 个人体重为 wi(0≤i<n)。每艘船的最大载重量均为 C,且最多只能乘两个人。用最少的船装载所有人。

【编程实现】JAVA版:

import java.util.Arrays;
import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner in=new Scanner(System.in);
		int n=in.nextInt();
		int c=in.nextInt();
		int a[]=new int[n];
		for(int i=0;i<n;i++) {
			a[i]=in.nextInt();
		}
		Arrays.sort(a);
		int ans=0,i=0,j=n-1;
		while(i<j)
		{	if(a[i]+a[j]<=c) {
				ans++;
				i++;
				j--;
			}
			else {
				ans++;
				j--;
			}
		}
		if(i==j)System.out.println(ans+1);
		else System.out.println(ans);
		}

}

【执行结果】

 

全部评论

相关推荐

不愿透露姓名的神秘牛友
11-26 18:54
点赞 评论 收藏
分享
去B座二楼砸水泥地:不过也可以理解,这种应该没参加过秋招
点赞 评论 收藏
分享
喜欢走神的孤勇者练习时长两年半:爱华,信华,等华,黑华
点赞 评论 收藏
分享
2 2 评论
分享
牛客网
牛客企业服务