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

coreBugZJ

此 blog 已棄。

A hard Aoshu Problem, ACM/ICPC 2010/2011 亞洲,福州區(qū)域賽 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 閱讀(2124) 評論(3)  編輯 收藏 引用 所屬分類: ACM

Feedback

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

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

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

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

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

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


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲一区二区三区中文字幕| 日韩写真在线| 一本色道久久综合亚洲精品不 | 亚洲人成毛片在线播放| 久久久一区二区| 亚洲精品影视| 久久伊伊香蕉| 欧美高清在线精品一区| 国产亚洲一区二区三区在线观看 | 亚洲国产精品悠悠久久琪琪 | 欧美专区日韩专区| 亚洲精选久久| 国产精品日本精品| av72成人在线| 亚洲一区二区三区影院| 欧美国产国产综合| 亚洲综合日韩中文字幕v在线| 亚洲人成网站在线观看播放| 欧美性做爰猛烈叫床潮| 99热在线精品观看| 亚洲图片欧洲图片日韩av| 欧美日韩极品在线观看一区| 亚洲国产人成综合网站| 久久精品视频在线看| 午夜精品久久久久久久99樱桃| 国产精品theporn88| 久久久久一区二区| 欧美剧在线观看| 99国内精品久久| 亚洲女同同性videoxma| 国产日韩一区在线| 久久一区二区三区四区五区| 欧美一区二区三区在线| 韩国成人福利片在线播放| 久久久久国产精品厨房| 欧美在线资源| 韩日精品中文字幕| 黄色成人精品网站| 亚洲一级影院| 久久视频在线视频| 亚洲欧美日韩系列| 亚洲色诱最新| 国产麻豆视频精品| 久久婷婷国产综合国色天香| 欧美伦理91i| 久久久久国产一区二区| 亚洲一区在线视频| 亚洲日本欧美在线| 亚洲人体一区| 国产一区二区黄色| 一区二区成人精品| 国产精品亚洲综合久久| 亚洲国产一区二区精品专区| 国产欧美日韩一区二区三区在线观看 | 国产视频亚洲精品| 亚洲精品少妇| 尤物yw午夜国产精品视频| 奶水喷射视频一区| 男女精品视频| 99国产精品久久久久老师| 欧美中文在线视频| 亚洲综合精品自拍| 欧美激情视频免费观看| 亚洲中无吗在线| 欧美成人精品在线视频| 国产一区二区三区久久久| 一本不卡影院| 国产日韩综合| 在线亚洲一区二区| 日韩性生活视频| 久久伊人免费视频| 久久免费精品视频| 欧美日韩亚洲一区二区| 欧美一区二区三区免费视| 欧美在线免费| 欧美一区二区日韩一区二区| 欧美日韩麻豆| 亚洲黄色成人久久久| 亚洲第一天堂av| 中文一区在线| 一区二区三区高清在线| 亚洲欧美日韩国产| 亚洲一区免费网站| 欧美日产在线观看| 亚洲国产女人aaa毛片在线| 一区二区三区日韩精品视频| 国产午夜精品麻豆| 亚洲在线观看视频| 午夜精品电影| 久久躁日日躁aaaaxxxx| 久久久久看片| 国产亚洲亚洲| 性欧美办公室18xxxxhd| 99re热这里只有精品视频| 免费不卡在线观看av| 亚洲欧美综合精品久久成人| 欧美日本韩国在线| 亚洲人成网站777色婷婷| 亚洲欧洲在线观看| 亚洲欧美偷拍卡通变态| 先锋影音网一区二区| 欧美国产欧美综合| 亚洲国产精品久久久久秋霞不卡| 亚洲国产高清aⅴ视频| 亚洲午夜羞羞片| 亚洲欧美大片| 欧美性猛交xxxx乱大交退制版| 日韩一区二区精品视频| 亚洲国产欧美在线| 欧美高清你懂得| 亚洲人成欧美中文字幕| 亚洲精品一区二区网址 | 欧美成人三级在线| 亚洲国产91| 国产自产女人91一区在线观看| 亚洲国产精品t66y| 99国产精品久久久久久久成人热| 欧美日韩精品一区| 亚洲视频碰碰| 欧美制服丝袜第一页| 国产综合视频在线观看| 久久精品亚洲热| 性做久久久久久久免费看| 国产精品手机在线| 午夜在线观看欧美| 裸体一区二区三区| 国产女主播一区二区三区| 新狼窝色av性久久久久久| 久久影院午夜片一区| 欧美日韩国内| 亚洲欧美三级伦理| 蜜臀久久久99精品久久久久久| 国产精品视频999| 欧美一区二区在线免费播放| 免费在线亚洲| 日韩网站在线| 国产精品萝li| 一区二区三区日韩在线观看| 欧美一区二区日韩| 亚洲第一久久影院| 欧美日韩精品一区二区三区四区| 亚洲一区二区精品| 久久精品国产77777蜜臀| 午夜一区二区三区在线观看| 国产一区二区高清视频| 久久亚洲风情| 99re6热在线精品视频播放速度 | 欧美日韩调教| 亚洲欧美日韩天堂一区二区| 六月丁香综合| 日韩午夜激情电影| 国产伦精品一区二区三区在线观看| 亚洲欧美在线观看| 欧美激情视频在线播放| 亚洲成人在线| 欧美日韩亚洲视频一区| 亚欧美中日韩视频| 亚洲国产成人在线| 性久久久久久久| 亚洲韩国精品一区| 国产精品国产三级国产专播精品人| 99www免费人成精品| 久久精品国内一区二区三区| 亚洲福利一区| 国产精品美女久久| 麻豆精品91| 亚洲在线一区二区三区| 久久综合狠狠综合久久综青草| 夜色激情一区二区| 国内成+人亚洲| 欧美日韩亚洲天堂| 久久亚洲一区| 亚洲视频图片小说| 欧美国产日韩一区| 性做久久久久久免费观看欧美| 最新69国产成人精品视频免费| 国产精品色在线| 欧美成人有码| 性欧美激情精品| 亚洲精品日韩综合观看成人91| 久久久噜噜噜久久狠狠50岁| 这里只有精品在线播放| 在线成人亚洲| 国产精品一区二区久久精品| 乱中年女人伦av一区二区| 亚洲资源av| 亚洲精品在线观看免费| 噜噜噜躁狠狠躁狠狠精品视频 | 欧美日韩一区二区三区在线看| 久久久www成人免费精品| 亚洲色无码播放| 亚洲国产婷婷香蕉久久久久久99| 久久国产精品久久国产精品| 在线天堂一区av电影| 亚洲国产第一| 国内成人在线| 国产精品欧美在线| 欧美日韩二区三区| 久久精品在这里| 午夜日韩在线观看|