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

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 閱讀(2105) 評論(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>
            在线视频亚洲一区| 欧美主播一区二区三区| 亚洲国产精品久久| 在线观看国产精品网站| 亚洲韩国精品一区| 亚洲免费视频成人| 久久精品一区二区国产| 欧美激情久久久| 一本综合久久| 久久综合激情| 国产精品免费在线 | 99视频有精品| 欧美一二三区在线观看| 欧美激情一区二区三区在线视频| 欧美性天天影院| 亚洲丁香婷深爱综合| 欧美一区二区精品| 亚洲国产精品毛片| 欧美亚洲不卡| 久久亚洲春色中文字幕| 一区二区三区欧美| 激情欧美一区二区三区| 欧美一级大片在线免费观看| 亚洲黄色一区二区三区| 欧美一区二区三区四区高清 | 久久综合亚洲社区| 亚洲视频1区2区| 欧美成人xxx| 亚洲高清视频一区二区| 亚洲免费久久| 国产日韩欧美二区| 亚洲人成人一区二区三区| 欧美一区二区在线视频| 麻豆成人小视频| 国产一区二区三区久久久久久久久 | 久久国产欧美| 亚洲一区激情| 欧美四级电影网站| 亚洲伊人一本大道中文字幕| 夜夜嗨av一区二区三区| 在线观看欧美日韩| 亚洲午夜伦理| 国产亚洲精久久久久久| 亚洲精品一区二区三区99| 欧美精品一区二区三区在线看午夜 | 亚洲国产精品久久久久久女王| 中国成人黄色视屏| 日韩写真视频在线观看| 亚洲东热激情| 激情懂色av一区av二区av| 亚洲特级毛片| 亚洲一区日韩| 欧美日韩一区二区免费在线观看| 国产精品99久久不卡二区| 女人天堂亚洲aⅴ在线观看| 亚洲欧洲综合另类在线| 久久久久久久综合| 亚洲美女色禁图| 一本久久a久久免费精品不卡| 亚洲福利精品| 美女网站久久| 欧美大片专区| 欧美日韩国产免费观看| 午夜视频在线观看一区二区三区 | 亚洲香蕉成视频在线观看| 99国产精品久久久久久久成人热| 老司机免费视频一区二区三区| 久久夜色精品国产亚洲aⅴ| 国内成人在线| 亚洲人成免费| 久久久精品网| 娇妻被交换粗又大又硬视频欧美| 欧美一区国产二区| 久久久久久久久久看片| 极品裸体白嫩激情啪啪国产精品| 久久精品国产99精品国产亚洲性色| 亚洲国产精品一区二区www在线| 久久久噜噜噜久久中文字免| 欧美大片在线观看一区二区| 亚洲日本va在线观看| 亚洲最新视频在线| 亚洲专区一区二区三区| 国产精品亚洲激情| 欧美激情一区三区| 亚洲美女在线视频| 国产精品福利网站| 亚洲精品国精品久久99热| 在线综合亚洲| 欧美xx视频| 免费日韩av片| 国产一区二区在线观看免费播放| 欧美在线999| 亚洲国产精品久久久久秋霞影院| 亚洲视频精品| 国产在线一区二区三区四区| 欧美岛国在线观看| 一区二区三区四区在线| 久久久99久久精品女同性| 91久久在线视频| 国产精品三级视频| 午夜精品在线看| 亚洲国产99| 国产精品婷婷午夜在线观看| 久久综合五月| 亚洲一区二区三区激情| 欧美激情自拍| 久久国产精品99精品国产| 欧美视频亚洲视频| 久久精品一区蜜桃臀影院| 久久人人爽人人爽| 黄色一区二区三区四区| 欧美日韩国产影片| 久久精品中文| 一区二区免费看| 欧美国产日韩一区二区三区| 亚洲欧美日韩综合aⅴ视频| 在线看日韩av| 久久久999精品免费| 一区二区久久久久| 亚洲国产婷婷| 久久综合亚州| 亚洲激情第一区| 国产伦精品一区二区三区| 新67194成人永久网站| 欧美在线观看视频在线| 99国产精品久久久久久久成人热| 国产综合视频| 国产精品视频成人| 欧美日韩一区二区免费在线观看| 免费视频一区二区三区在线观看| 性欧美xxxx大乳国产app| 一区二区免费在线视频| 亚洲精品一区久久久久久| 欧美插天视频在线播放| 久久久久久久久久久一区 | 久久综合伊人77777| 午夜欧美不卡精品aaaaa| 9色精品在线| 国产精品自拍小视频| 欧美视频一区二区在线观看| 欧美精品在线视频| 欧美日本一区二区三区| 欧美日本在线播放| 欧美日韩不卡合集视频| 欧美另类女人| 欧美日韩免费观看一区二区三区| 欧美精品国产一区| 欧美日本一区二区高清播放视频| 欧美精品自拍偷拍动漫精品| 欧美人与禽性xxxxx杂性| 欧美激情在线| 欧美日韩亚洲一区在线观看| 嫩模写真一区二区三区三州| 女仆av观看一区| 欧美另类久久久品| 国产精品高精视频免费| 国产精品入口| 一区精品在线| 日韩西西人体444www| 亚洲一区久久久| 久久丁香综合五月国产三级网站| 久久久人成影片一区二区三区观看| 久久久久久久999精品视频| 免费在线观看精品| 亚洲精品乱码久久久久久久久| 一区二区三区日韩精品| 欧美一区二区大片| 免费成人你懂的| 欧美性猛交xxxx免费看久久久| 国产精品自在在线| 亚洲高清影视| 亚洲欧美中日韩| 欧美freesex交免费视频| 亚洲欧洲视频| 午夜精品久久久久久久99热浪潮| 日韩视频在线免费| 欧美一区免费视频| 欧美激情性爽国产精品17p| 欧美日韩专区| 伊人一区二区三区久久精品| 这里只有精品视频| 久久婷婷蜜乳一本欲蜜臀| 亚洲欧洲在线免费| 性久久久久久久久| 欧美日本国产一区| 伊人精品在线| 亚洲欧美经典视频| 欧美激情一区二区| 亚洲欧美日韩天堂| 欧美人交a欧美精品| 激情小说亚洲一区| 亚洲欧美不卡| 亚洲精品日产精品乱码不卡| 欧美在线一区二区三区| 欧美色道久久88综合亚洲精品| 亚洲国产天堂网精品网站| 久久超碰97人人做人人爱| 亚洲精品国产品国语在线app| 久久久午夜电影| 国产欧美一区二区三区久久人妖|