本题主要利用贪心算法,主要意思就是将1*1,2*2,到6*6的包放进6*6的包里,求出可以使用的最少的包的个数
输入的6个数据分别对应1*1到6*6的包的个数。
//n1到n6记录1*1到6*6的包的个数,t1和t2记录6,5,4,3之后填完所能填充的1*1和2*2的包
1
#include
<
stdio.h
>
2 int main()
3 {
4 int s1[ 4 ] = { 0 , 7 , 6 , 5 }; // 根据n3%4,判断此包中填入3*3,2*2后还能填入1*1的个数
5 int s2[ 4 ] = { 0 , 5 , 3 , 1 }; // 根据n3%4,判断此包中填入3*3后还能填入的2*2的个数
6 int n1,n2,n3,n4,n5,n6,t1,t2,sum;
7 while ( 1 )
8 {
9 scanf( " %d%d%d%d%d%d " , & n1, & n2, & n3, & n4, & n5, & n6);
10 if (n1 == 0 && n2 == 0 && n3 == 0 && n4 == 0 && n5 == 0 && n6 == 0 )
11 break ;
12 sum = n6 + n5 + n4 + n3 / 4 ; // 先计算出填完6,5,4,3所需的包的个数
13 if (n3 % 4 != 0 ) // 如果3*3填完后有剩余,补充一个包
14 sum ++ ;
15 t2 = 5 * n4 + s2[n3 % 4 ]; // 所能填入的2*2的包
16 t1 = 11 * n5 + s1[n3 % 4 ]; // 所能填入的1*1的包
17 n2 -= t2; // 将2*2填入后还能填入的2*2的个数
18 if (n2 > 0 ) // 如果n2大于0,则在补充包
19 {
20 sum += n2 / 9 ;
21 if (n2 % 9 ) // 仍有剩余,继续补充一个
22 {
23 ++ sum;
24 t1 += 36 - (n2 % 9 ) * 4 ; // 填入2*2后剩余的需用1*1的补充
25 }
26 }
27 else
28 t1 -= n2 * 4 ; // 如果n2小于0,则需用1*1补充
29 n1 -= t1; // 所能填入的1*1的包
30 if (n1 > 0 ) // 同n2,添加1*1的包
31 {
32 sum += n1 / 36 ;
33 if (n1 % 36 ) // 若仍有剩余,再添加一个
34 ++ sum;
35 }
36 printf( " %d\n " ,sum);
37 }
38 return 0 ;
39 }
2 int main()
3 {
4 int s1[ 4 ] = { 0 , 7 , 6 , 5 }; // 根据n3%4,判断此包中填入3*3,2*2后还能填入1*1的个数
5 int s2[ 4 ] = { 0 , 5 , 3 , 1 }; // 根据n3%4,判断此包中填入3*3后还能填入的2*2的个数
6 int n1,n2,n3,n4,n5,n6,t1,t2,sum;
7 while ( 1 )
8 {
9 scanf( " %d%d%d%d%d%d " , & n1, & n2, & n3, & n4, & n5, & n6);
10 if (n1 == 0 && n2 == 0 && n3 == 0 && n4 == 0 && n5 == 0 && n6 == 0 )
11 break ;
12 sum = n6 + n5 + n4 + n3 / 4 ; // 先计算出填完6,5,4,3所需的包的个数
13 if (n3 % 4 != 0 ) // 如果3*3填完后有剩余,补充一个包
14 sum ++ ;
15 t2 = 5 * n4 + s2[n3 % 4 ]; // 所能填入的2*2的包
16 t1 = 11 * n5 + s1[n3 % 4 ]; // 所能填入的1*1的包
17 n2 -= t2; // 将2*2填入后还能填入的2*2的个数
18 if (n2 > 0 ) // 如果n2大于0,则在补充包
19 {
20 sum += n2 / 9 ;
21 if (n2 % 9 ) // 仍有剩余,继续补充一个
22 {
23 ++ sum;
24 t1 += 36 - (n2 % 9 ) * 4 ; // 填入2*2后剩余的需用1*1的补充
25 }
26 }
27 else
28 t1 -= n2 * 4 ; // 如果n2小于0,则需用1*1补充
29 n1 -= t1; // 所能填入的1*1的包
30 if (n1 > 0 ) // 同n2,添加1*1的包
31 {
32 sum += n1 / 36 ;
33 if (n1 % 36 ) // 若仍有剩余,再添加一个
34 ++ sum;
35 }
36 printf( " %d\n " ,sum);
37 }
38 return 0 ;
39 }