青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

coreBugZJ

此 blog 已棄。

A hard Aoshu Problem, ACM/ICPC 2010/2011 亞洲,福州區域賽 J, UVA 5107

5107 - A hard Aoshu Problem
Asia - Fuzhou - 2010/2011

 

Math Olympiad is called ``Aoshu" in China. Aoshu is very popular in elementary schools. Nowadays, Aoshu is getting more and more difficult. Here is a classic Aoshu problem:

 

 

ABBDE$\displaystyle \_$$\displaystyle \_$$\displaystyle \_abccc$ = BDBDE

In the equation above, a letter stands for a digit(0 - 9), and different letters stands for different digits. You can fill the blank with `+', `-`, ` x' or `÷'.

How to make the equation right? Here is a solution:

 

 

12245 + 12000 = 24245

In that solution, A = 1, B = 2, C = 0, D = 4, E = 5, and `+' is filled in the blank.

When I was a kid, finding a solution is OK. But now, my daughter's teacher tells her to find all solutions. That's terrible. I doubt whether her teacher really knows how many solutions are there. So please write a program for me to solve this kind of problems.

 

Input 

The first line of the input is an integer T (T$ \le$20) indicating the number of test cases.

Each test case is a line which is in the format below:

 


s1 s2 s3

 


s1, s2 and s3 are all strings which are made up of capital letters. Those capital letters only include ` A',' B', ' C',' D' and ` E', so forget about ` F' to ` Z'. The length of s1, s2 or s3 is no more than 8.

When you put a `=' between s2 and s3, and put a operator (`+','-`, ` x' or `÷'.) between s1 and s2, and replace every capital letter with a digit, you get a equation.

You should figure out the number of solutions making the equation right.

Please note that same letters must be replaced by same digits, and different letters must be replaced by different digits.

If a number in the equation is more than one digit, it must not have leading zero.

 

Output 

For each test case, print an integer in a line. It represents the number of solutions.

 

Sample Input 

 

2 
A A A
BCD BCD B

 

Sample Output 

 

5
72

Fuzhou 2010-2011


暴力搜索之。。。

我的代碼:

 1 #include <stdio.h>
 2 #include <string.h>
 3 
 4 typedef long long Lint;
 5 
 6 #define  L  10
 7 
 8 char s1[ L ], s2[ L ], s3[ L ];
 9 
10 #define  DIGIT  6
11 
12 int digit[ DIGIT ], used[ DIGIT ];
13 int a[ L ], b[ L ], c[ L + L ];
14 
15 void parse( char s[], int a[], int size ) {
16         int i, len = strlen( s );
17         memset( a, 0, size );
18         for ( i = 0; i < len; ++i ) {
19                 used[ a[ len - i - 1 ] = s[ i ] - 'A' + 1 ] = 1;
20         }
21 }
22 
23 void init() {
24         memset( used,  0sizeof(used)  );
25         parse( s1, a, sizeof(a) );
26         parse( s2, b, sizeof(b) );
27         parse( s3, c, sizeof(c) );
28 }
29 
30 int parseInt( int a[], int n, Lint *num ) {
31         int i = n-1;
32         while ( (i>=0&& (a[i]==0) ) --i;
33         if ( (i<0|| ((i>0)&&(digit[a[i]]==0)) ) return 0;
34         *num = 0;
35         for ( ; i >= 0--i ) {
36                 if ( digit[ a[ i ] ] > 9 ) return 0;
37                 *num = (*num) * 10 + digit[ a[ i ] ];
38         }
39         return 1;
40 }
41 
42 int equal() {
43         Lint x, y, z;
44         int i, ans = 0;
45         for ( i = 1; i < DIGIT; ++i ) {
46                 if ( (digit[i]<10&& (used[i]==0) ) {
47                         return 0;
48                 }
49         }
50         if ( !parseInt( a, sizeof(a)/sizeof(a[0]), &x ) ) return 0;
51         if ( !parseInt( b, sizeof(b)/sizeof(b[0]), &y ) ) return 0;
52         if ( !parseInt( c, sizeof(c)/sizeof(c[0]), &z ) ) return 0;
53         if ( x + y == z ) ++ans;
54         if ( x - y == z ) ++ans;
55         if ( x * y == z ) ++ans;
56         if ( (y!=0&& (x%y==0&& (x/y==z) ) ++ans;
57         return ans;
58 }
59 
60 int solve() {
61         int ans = 0, have[ 22 ] = { 0 };
62 #define  F(i) for ( digit[ i ] = 0; digit[ i ] < 11; ++digit[ i ] ) { \
63                 if ( have[ digit[ i ] ] ) continue; \
64                 if ( digit[ i ] < 10 ) have[ digit[ i ] ] = 1;
65 #define  E(i)  have[ digit[ i ] ] = 0; \
66         }
67         F(1) F(2) F(3) F(4) F(5) {
68                 ans += equal();
69         } E(5) E(4) E(3) E(2) E(1)
70         return ans;
71 }
72 
73 int main() {
74         int td;
75         scanf( "%d"&td );
76         while ( td-- > 0 ) {
77                 scanf( "%s%s%s", s1, s2, s3 );
78                 init();
79                 printf( "%d\n", solve() );
80         }
81         return 0;
82 }
83 


posted on 2011-03-24 22:14 coreBugZJ 閱讀(2119) 評論(3)  編輯 收藏 引用 所屬分類: ACM

Feedback

# re: A hard Aoshu Problem, ACM/ICPC 2010/2011 亞洲,福州區域賽, UVA 5107 2011-03-25 09:53 電腦知識與技術

全都是英文。看不懂啊  回復  更多評論   

# re: A hard Aoshu Problem, ACM/ICPC 2010/2011 亞洲,福州區域賽, UVA 5107[未登錄] 2011-03-25 15:45 Bill

純建議,不要一次發一堆文章到主頁上。可以慢慢發。  回復  更多評論   

# re: A hard Aoshu Problem, ACM/ICPC 2010/2011 亞洲,福州區域賽, UVA 5107 2011-03-25 16:21 coreBugZJ

@Bill
我是剛來的菜鳥,不懂事,謝謝提醒。。。  回復  更多評論   


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区高清视频在线观看| 亚洲激情婷婷| 亚洲欧美一级二级三级| 国产精品尤物| 免费日韩av| 欧美第一黄色网| 中文一区二区在线观看| 在线亚洲伦理| 国模一区二区三区| 欧美国产精品v| 欧美日韩午夜在线| 久久精品视频在线观看| 老司机一区二区三区| aa日韩免费精品视频一| 亚洲一区三区视频在线观看| 国产主播一区二区三区| 最新中文字幕一区二区三区| 国产精品久久久久久久免费软件| 久久激情一区| 欧美韩日一区二区| 欧美一二三视频| 老牛嫩草一区二区三区日本 | 欧美日韩一区二区在线视频| 香蕉成人久久| 免费av成人在线| 亚洲欧美在线x视频| 久久久精品国产一区二区三区 | 欧美亚洲成人精品| 另类人畜视频在线| 欧美体内she精视频| 美玉足脚交一区二区三区图片| 欧美人体xx| 蜜臀a∨国产成人精品 | 久久久久久久久久久一区| 亚洲美女精品成人在线视频| 亚洲专区国产精品| 日韩亚洲欧美在线观看| 久久精品最新地址| 午夜欧美电影在线观看| 欧美伦理a级免费电影| 久久一综合视频| 国产裸体写真av一区二区| 亚洲国产免费| 在线视频观看日韩| 欧美影院在线播放| 午夜精品三级视频福利| 欧美女同在线视频| 亚洲国产精品福利| 在线观看欧美日韩| 亚洲欧美国产精品专区久久| 亚洲午夜成aⅴ人片| 欧美电影免费观看高清| 欧美国产一区二区| 在线看视频不卡| 久久久欧美一区二区| 久久精品成人一区二区三区蜜臀| 欧美性猛交xxxx乱大交蜜桃| 亚洲美女色禁图| 9国产精品视频| 欧美国产精品日韩| 亚洲品质自拍| 夜夜嗨av一区二区三区四区| 另类欧美日韩国产在线| 欧美成人精精品一区二区频| 国内精品写真在线观看| 久久国产精品久久国产精品| 久久精品免视看| 狠狠色综合日日| 久久激情视频| 免费久久99精品国产| 亚洲第一综合天堂另类专| 美女视频网站黄色亚洲| 亚洲激情自拍| 91久久精品国产91久久| 欧美成在线观看| 日韩亚洲欧美在线观看| 亚洲一区二区三区四区视频| 国产精品理论片| 欧美在线三区| 欧美激情视频在线播放 | 国产日韩欧美一区二区三区在线观看| 亚洲视频中文| 久久精品亚洲一区二区三区浴池| 国产在线精品自拍| 久热精品视频在线观看| 亚洲精品日韩综合观看成人91| 一区二区欧美在线| 国产欧美日韩一区二区三区在线观看 | 一本一本久久a久久精品综合麻豆| 一区二区三区四区精品| 国产精品一区免费视频| 久久精品国产免费看久久精品| 欧美插天视频在线播放| 在线亚洲自拍| 狠狠爱综合网| 欧美精品在线视频| 香蕉国产精品偷在线观看不卡| 久热精品视频在线观看一区| 亚洲美女视频在线观看| 国产精品嫩草久久久久| 麻豆国产精品777777在线| 在线亚洲精品福利网址导航| 久久久久久尹人网香蕉| 一区二区日韩免费看| 国产亚洲视频在线观看| 欧美日韩调教| 久久亚洲午夜电影| 亚洲一区二区成人在线观看| 牛牛影视久久网| 小嫩嫩精品导航| 亚洲精品一区在线| 国产在线精品二区| 欧美视频一区在线观看| 久久网站免费| 欧美一级精品大片| 日韩亚洲欧美一区二区三区| 国产一区二区在线观看免费播放| 久久米奇亚洲| 亚洲激情午夜| 国产日本欧美视频| 欧美日韩高清在线| 久久人人爽国产| 香蕉久久a毛片| 亚洲午夜久久久久久久久电影网| 欧美国产综合视频| 久久综合网络一区二区| 久久成人精品视频| 亚洲一区黄色| 亚洲一区二区动漫| 一区二区电影免费在线观看| 亚洲国产精品一区二区三区| 国产日韩欧美制服另类| 国产精品入口尤物| 欧美视频国产精品| 欧美日韩激情网| 欧美精品aa| 欧美国产三区| 欧美风情在线| 欧美激情亚洲国产| 欧美极品欧美精品欧美视频| 久久久久久婷| 久久婷婷麻豆| 欧美成人精品一区二区| 久久综合狠狠综合久久综合88| 久久不射2019中文字幕| 久久精品女人| 久久青草福利网站| 男人天堂欧美日韩| 欧美成人午夜免费视在线看片| 欧美a级大片| 欧美日韩123| 国产精品xvideos88| 国产精品视频一区二区三区 | 亚洲国产高清一区二区三区| 欧美暴力喷水在线| 亚洲国产精品一区二区尤物区| 免费观看成人www动漫视频| 欧美福利一区二区| 日韩视频一区二区三区在线播放| 亚洲三级性片| 亚洲一区免费| 久久久国产91| 欧美精品1区2区| 国产精品人人做人人爽人人添| 国产精品国产三级国产aⅴ浪潮 | 免费一级欧美片在线播放| 欧美mv日韩mv国产网站| 欧美日韩在线不卡一区| 国产精品日韩欧美大师| 精品69视频一区二区三区| 亚洲欧洲精品成人久久奇米网| 在线视频欧美精品| 久久久久国内| 亚洲精品国产系列| 羞羞色国产精品| 嫩草影视亚洲| 国产日韩欧美麻豆| 亚洲精品小视频在线观看| 亚洲欧美日本日韩| 欧美大片网址| 亚洲自拍三区| 欧美国产日韩一区二区三区| 国产精品日韩在线播放| 亚洲激情专区| 久久国产欧美日韩精品| 最新成人在线| 久久gogo国模啪啪人体图| 欧美日产国产成人免费图片| 国产综合视频| 欧美亚洲视频一区二区| 亚洲国产成人久久综合| 午夜精品一区二区三区电影天堂| 欧美国产视频一区二区| 狠狠色香婷婷久久亚洲精品| 亚洲在线观看免费视频| 亚洲国产欧美不卡在线观看 | 亚洲精品美女在线观看播放| 欧美诱惑福利视频| 国产精品免费久久久久久| 99国产精品99久久久久久|