1766. 火柴棒等式【转】

http://blog.csdn.net/luojiayu14/article/details/7090499

1766. 火柴棒等式

Description

 

给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A、B、C是用火柴棍拼出的整数(若该数非零,则最高位不能是0)。用火柴棍拼数字0-9的拼法如图所示:

注意:

1. 加号与等号各自需要两根火柴棍

2. 如果A≠B,则A+B=C与B+A=C视为不同的等式(A、B、C>=0)

3. n根火柴棍必须全部用上

Input

输入有多组Case,每组Case共一行,一个整数n(n<=24)。

Output

每组Case输出一行,表示能拼成的不同等式的数目。

Sample Input

14

Sample Output

2
 1 #include <iostream>
 2 using namespace std;
 3 
 4 int b[10]={6,2,5,5,4,5,6,3,7,6},a[2230]={0},n;
 5 
 6 int main()
 7 {    
 8     for(int i=0;i<10;i++)
 9         a[i]=b[i];
10     for(int i=10;i<2225;i++)
11     {
12         int t=i;
13         while(t)
14         {
15             a[i]+=a[t%10];
16             t/=10;
17         }
18     }
19     while(cin>>n)
20     {
21         int m,count=0;
22         m=n-4;
23         for(int i=0;i<1112;i++)
24         {
25             for(int j=0;j<1112;j++)
26             {
27                 if(a[i]+a[j]+a[i+j]==m)
28                     count++;
29             }
30         }
31         cout<<count<<endl;
32     }
33     return 0;
34 }
35     

更详细的题解:http://www.cnblogs.com/shally/articles/2128321.html

 

 

 

posted on 2014-07-09 17:53  华山青竹  阅读(162)  评论(0编辑  收藏  举报

导航