算法期末考试题目+代码
【问题描述】
求解乘船问题。有 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);
}
}
【执行结果】