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

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 閱讀(2105) 評(píng)論(3)  編輯 收藏 引用 所屬分類: ACM

Feedback

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

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

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

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

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

@Bill
我是剛來(lái)的菜鳥(niǎo),不懂事,謝謝提醒。。。  回復(fù)  更多評(píng)論   


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美黑人多人双交| 亚洲第一黄色网| 国产日韩欧美高清| 国产精品伦子伦免费视频| 欧美日本中文| 欧美理论片在线观看| 欧美精品999| 欧美视频久久| 国产精品自在欧美一区| 国产日韩欧美在线视频观看| 国产亚洲毛片| 亚洲国产精品第一区二区| 亚洲国产人成综合网站| 最新中文字幕亚洲| 在线午夜精品| 久久九九全国免费精品观看| 久久成人羞羞网站| 欧美成人国产| 一本色道久久加勒比88综合| 午夜视黄欧洲亚洲| 欧美成年人网| 国产精品日韩欧美大师| 在线日韩精品视频| 亚洲一区在线观看视频 | 亚洲欧美日韩网| 久久久久久香蕉网| 蜜臀av性久久久久蜜臀aⅴ| 欧美三区在线视频| 欧美大片第1页| 日韩午夜在线播放| 久久人人爽爽爽人久久久| 欧美日韩日日骚| 激情综合电影网| 羞羞视频在线观看欧美| 91久久精品网| 久久久999| 国产午夜亚洲精品羞羞网站| 一区二区三区免费看| 欧美91福利在线观看| 性18欧美另类| 国产精品亚发布| 亚洲一区二区三区国产| 亚洲国产精品毛片| 嫩草伊人久久精品少妇av杨幂| 亚洲欧洲精品一区二区| 久久av免费一区| 国产精品嫩草影院一区二区| 日韩一区二区免费看| 欧美成人精品激情在线观看| 久久久精品性| 伊甸园精品99久久久久久| 久久www成人_看片免费不卡| 亚洲综合欧美日韩| 国产精品视频xxxx| 亚洲综合久久久久| 一本一本久久a久久精品综合妖精| 欧美电影打屁股sp| 亚洲国产综合91精品麻豆| 欧美成人网在线| 久热精品视频在线| 亚洲电影免费观看高清| 欧美高清视频在线观看| 欧美成人小视频| 日韩视频在线一区二区| 亚洲国产日韩欧美一区二区三区| 久久麻豆一区二区| 亚洲第一免费播放区| 欧美岛国激情| 男女av一区三区二区色多| 亚洲片在线观看| 野花国产精品入口| 国产精品五月天| 久久精品国产亚洲5555| 久久精品国产综合精品| 亚洲成人在线网站| 亚洲黄色高清| 国产精品va在线| 久久久国产精品亚洲一区| 久久精品女人的天堂av| 91久久精品美女高潮| 亚洲理伦电影| 国产欧美一区二区三区在线老狼 | 亚洲精品日韩一| 欧美成人一区二区三区| 免费精品99久久国产综合精品| 有坂深雪在线一区| 亚洲电影观看| 国产精品欧美经典| 麻豆精品一区二区av白丝在线| 久久综合国产精品| 一区二区三区高清在线观看| 午夜精品久久久久久| 亚洲国产精品一区二区第四页av| 亚洲精品欧美| 国产精品视频专区| 免费高清在线视频一区·| 欧美精品乱码久久久久久按摩| 亚洲一区二区三区精品视频| 久久免费视频一区| 亚洲一区二区精品在线| 久久久久一区| 午夜电影亚洲| 欧美xxx成人| 久久全球大尺度高清视频| 欧美日韩精品一二三区| 久久一区二区三区国产精品| 欧美日韩亚洲一区二区三区在线观看 | 欧美日韩一区二区三区免费| 久久久久免费观看| 国产精品爱啪在线线免费观看 | 亚洲私人影院在线观看| 亚洲国产黄色片| 亚洲主播在线| 一本色道久久精品| 久久一二三国产| 久久精品视频导航| 欧美午夜免费影院| 亚洲人成人77777线观看| 精品成人乱色一区二区| 中日韩美女免费视频网址在线观看 | 亚洲欧美日韩国产综合精品二区 | 国产在线一区二区三区四区 | 欧美午夜寂寞影院| 亚洲高清视频的网址| 韩国一区电影| 欧美在线观看一区二区| 午夜精品成人在线视频| 欧美性大战久久久久久久| 日韩视频一区二区在线观看 | 欧美亚洲成人精品| 麻豆9191精品国产| 国产麻豆精品theporn| 亚洲精品免费一区二区三区| 一区二区三区我不卡| 欧美一区二区三区视频免费| 欧美一区二区三区免费大片| 国产精品伦理| 亚洲午夜久久久| 欧美影院成人| 国产在线精品一区二区夜色| 午夜精品久久久久久久99水蜜桃| 亚洲欧美国产精品桃花| 国产精品久久久久久久久久免费看 | 亚洲午夜久久久久久久久电影院| 中文欧美字幕免费| 欧美午夜宅男影院| 亚洲伊人一本大道中文字幕| 欧美亚洲在线视频| 国产欧美午夜| 久久免费黄色| 亚洲精品护士| 午夜在线成人av| 红桃视频成人| 欧美激情精品久久久久| 夜夜爽av福利精品导航 | 亚洲福利视频一区二区| 亚洲久色影视| 国产精品福利网站| 亚洲欧美另类在线观看| 久久久夜色精品亚洲| 亚洲韩日在线| 欧美午夜影院| 久久国产天堂福利天堂| 六月天综合网| 亚洲精品一区二区在线观看| 欧美日韩国产成人在线观看| 亚洲免费久久| 久久久久国产精品一区| 最新高清无码专区| 国产精品国产福利国产秒拍| 久久黄色级2电影| 亚洲精品乱码| 久久久国产午夜精品| 最新成人在线| 国产日韩欧美综合在线| 欧美a级一区| 亚洲一区二区三区精品在线| 美国三级日本三级久久99| 亚洲一二三区在线观看| 好吊日精品视频| 欧美丝袜一区二区| 久久视频免费观看| 亚洲午夜在线| 最近中文字幕日韩精品| 久久久久久高潮国产精品视| 一区二区日韩精品| 在线观看成人av| 国产精品日韩在线| 欧美激情亚洲一区| 久久精品观看| 亚洲一区二区三区精品在线| 亚洲福利视频网站| 蜜桃久久av一区| 欧美剧在线观看| 亚洲一区二区三区视频| 影音先锋久久| 国产色产综合产在线视频| 欧美日韩久久久久久| 玖玖玖免费嫩草在线影院一区| 亚洲伊人网站|