sicily 6272. n钱m鸡问题

Description

一只公鸡值五文钱;

一只母鸡值三文钱;三只小鸡值一文钱

。请问用n文钱买m只鸡的方案有多少种?

Input

输入有多个case,

每个case如下

n m

其中n,m <= 100,

输入以EOF结束。

Output

对于每个case输出一行,

这一行只有一个整数,表示解的个数

 

后记:除了小鸡数=总数-公鸡数-母鸡数以外,还可以用只有小鸡数能被3整除时才开始计算花费,而不是在枚举时检验花费的同时一起检验小鸡数是否能被3整除的方法进一步减少计算量。

一开始用做实验的算法直接提交,WA无数次,屡改屡败。

被报错n次的其中一种,用小鸡数=总数-公鸡数-母鸡数控制枚举次数

View Code
 1 #include<stdio.h>
 2 int main()
 3 {
 4     int cock, hen, chick, n, m, cost, counter=0, num;
 5     
 6     while( scanf("%d%d", &n, &m ) != EOF )
 7     {
 8         for( cock = 0; cock <= n/5; cock++ )
 9         {
10             for( hen = 0; hen <= n/3; hen++ )
11             {
12                   chick = m - cock - hen;
13                 cost = cock * 5 + hen * 3 + (chick / 3);
14                 num = hen + chick + cock; 
15                  if ( (cost == n) && (num == m) && (chick % 3 ==0 )  )
16                   counter++;
17             }
18         }
19         printf("%d\n",counter);
20         counter = 0;
21     }
22     return 0;
23 } 

实在无奈,只好用比较笨的办法,三个循环,不控制枚举次数,居然成功AC了,但是run time达到了0.02sec

View Code
 1 #include<stdio.h>
 2 int main()
 3 {
 4     int cock, hen, chick, n, m, cost, counter=0;
 5     
 6     while( scanf("%d%d", &n, &m ) != EOF )
 7     {
 8         for( cock = 0; cock <= n/5; cock++ )
 9         {
10             for( hen = 0; hen <= n/3; hen++ )
11             {
12                 for( chick = 0; chick <= 3*n; chick++ )
13                 {
14                     cost = cock * 5 + hen * 3 + (chick / 3);
15                     if ( (cost == n) && (hen + chick + cock == m) && (chick % 3 ==0 )  )
16                     counter++;
17                 }
18                 
19             }
20         }
21         printf("%d\n",counter);
22         counter = 0;
23     }
24     return 0;
25 }                                 

在自己看来这两种算法本质都差不多,实在想不通为什么会出现不同的情况。于是存下来自己设计测试对比,在用100 20测试的时候发现了不同。

AC的程序在用100 20测试时解出的是1,而WA的那个是5.

修改代码查看具体每种解法


问题关键出现了,第二种算法把小鸡数为负的状况也算进去了。在控制条件里再加一个小鸡数不小于0,成功AC,Run Time 0sec

View Code
 1 #include<stdio.h>
 2 int main()
 3 {
 4     int cock, hen, chick, n, m, cost, counter=0, num;
 5     
 6     while( scanf("%d%d", &n, &m ) != EOF )
 7     {
 8         for( cock = 0; cock <= n/5; cock++ )
 9         {
10             for( hen = 0; hen <= n/3; hen++ )
11             {
12                 chick = m - cock - hen;
13                 cost = cock * 5 + hen * 3 + (chick / 3);
14                 num = hen + chick + cock; 
15                 if ( (cost == n) && (num == m) && (chick % 3 ==0 ) && (chick >= 0)  )
16                 {
17                     counter++;
18                 }
19             }
20         }
21         printf("%d\n",counter);
22         counter = 0;
23     }
24     return 0;
25 } 

还有一种更简单的办法,声明变量时使用unsigned,就直接避免了负数的出现,也AC了,Run Time 0sec

View Code
posted @ 2012-11-01 22:55  Joyee  阅读(687)  评论(0编辑  收藏  举报