poj1017 装箱问题 简单贪心



import java.io.BufferedInputStream;
import java.util.Scanner;

/**
* 分情况考虑贪心。关键是3*3的盒子怎么放。
* 6*6的放满整个盒子,
* 5*5的还可以放11个1*1。
* 4*4的还可以放5个2*2的。
* 3*3的总个数模4后,也就是说最后一个盒子放几个3*3的。
* 如果是1,还可以放5个2*2和7个1*1。
* 如果是2,可以放3个2*2和6个1*1。
* 如果是3,可以放1个2*2和5个1*1的。
* 2*2的模9就是最后一个箱子里放2*2的个数,36-(2*2的个数%9)就是可以放1*1的个数。
* 最后(1*1的个数+35)/36就是最后的盒子数。
* @author NC
*/
public class Main {

public static void main(String[] args) {
Scanner scan = new Scanner(new BufferedInputStream(System.in));
while (scan.hasNext()) {
int a1 = scan.nextInt();
int a2 = scan.nextInt();
int a3 = scan.nextInt();
int a4 = scan.nextInt();
int a5 = scan.nextInt();
int a6 = scan.nextInt();
if (a1 == 0 && a2 == 0 && a3 == 0 && a4 == 0 && a5 == 0 && a6 == 0) {
break;
}
int count = 0;
if (a6 > 0) {
count += a6;
}
if (a5 > 0) {
count += a5;
a1 = a1 - a5 * 11;
}
while (a4 > 0) {
count++;
if (a2 >= 5) {
a2 -= 5;
} else {
a1 = a1 - (5 - a2) * 4;
a2 = 0;
}
a4--;
}
count += a3 / 4;
a3 = a3 % 4;
if (a3 > 0) {
count++;
if (a3 == 1) {
if (a2 >= 5) {
a2 -= 5;
a1 -= 7;
} else {
a1 = a1 - (5 - a2) * 4 - 7;
a2 = 0;
}
} else if (a3 == 2) {
if (a2 >= 3) {
a2 -= 3;
a1 -= 6;
} else {
a1 = a1 - (3 - a2) * 4 - 6;
a2 = 0;
}
} else if (a3 == 3) {
if (a2 >= 1) {
a2 -= 1;
a1 -= 5;
} else {
a1 = a1 - 4 - 5;
a2 = 0;
}
}
}
if (a2 > 0) {
count += a2 / 9;//最初时,犯了个超低级错误。。。。36\(2*2)=18
a2 = a2 % 9;
if (a2 > 0) {
count++;
a1 = a1 - 4 * (9 - a2);
}
}

if (a1 > 0) {
count += a1 / 36;
a1 = a1 % 36;
if (a1 > 0) {
count++;
}
}
System.out.println(count);
}
}
}

你可能感兴趣的:(OJ,刷题)