poj1017 Packets

http://poj.org/problem?id=1017

本题主要利用贪心算法,主要意思就是将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 }

转载于:https://www.cnblogs.com/pcoda/articles/panda.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值