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

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一区| 欧美jizz19hd性欧美| 国产日韩视频| 午夜精品福利电影| 久久福利一区| 国产伦精品一区二区三区免费迷| 日韩视频在线一区二区| 日韩亚洲欧美一区| 欧美电影免费观看大全| 亚洲大片免费看| 亚洲精品国产精品乱码不99按摩| 另类综合日韩欧美亚洲| 欧美国产一区二区三区激情无套| 狠狠色狠狠色综合人人| 久久精品亚洲一区二区| 久久久综合精品| 在线观看成人一级片| 久久永久免费| 最新69国产成人精品视频免费| 最新亚洲一区| 欧美日韩国产精品自在自线| 日韩亚洲精品在线| 亚洲欧美日本国产专区一区| 国产精品v欧美精品v日本精品动漫 | 国产麻豆综合| 久久国产黑丝| 欧美成人一区二免费视频软件| 亚洲欧洲在线播放| 欧美精品在线免费观看| 一区二区三区国产精华| 欧美在线视频播放| 影音先锋中文字幕一区二区| 欧美顶级少妇做爰| 一区二区三区日韩精品视频| 久久精品中文字幕一区二区三区| 黄色亚洲在线| 欧美精品色一区二区三区| 一区二区欧美日韩| 久久精品首页| 亚洲精品孕妇| 国产三级欧美三级| 乱中年女人伦av一区二区| 99国产精品视频免费观看一公开| 销魂美女一区二区三区视频在线| 国模套图日韩精品一区二区| 美女爽到呻吟久久久久| 亚洲香蕉视频| 欧美va天堂在线| 亚洲欧美日韩一区二区三区在线观看| 国产视频在线观看一区二区三区| 麻豆精品传媒视频| 中日韩美女免费视频网站在线观看| 久久久999精品免费| 日韩一级视频免费观看在线| 国产欧美69| 欧美精品 日韩| 久久精品欧美日韩| 日韩一区二区精品视频| 麻豆视频一区二区| 性做久久久久久免费观看欧美| 在线看国产一区| 国产精品久久福利| 女仆av观看一区| 欧美一区二区在线看| 亚洲美女av在线播放| 玖玖视频精品| 欧美夜福利tv在线| 一区二区高清在线观看| 精品999在线观看| 国产伦精品一区二区三| 欧美三级电影大全| 欧美成人日韩| 久久蜜桃香蕉精品一区二区三区| 亚洲一区二区在线视频| 日韩亚洲欧美成人一区| 亚洲国产一区二区三区a毛片 | 一区二区欧美精品| 136国产福利精品导航| 国产在线精品一区二区中文| 欧美色图五月天| 欧美日韩久久| 欧美伦理91| 欧美护士18xxxxhd| 欧美高清视频免费观看| 久久久久久伊人| 久久久噜噜噜久久狠狠50岁| 欧美亚洲免费高清在线观看| 亚洲素人一区二区| 一区二区三区久久网| 日韩午夜av| 亚洲精品自在久久| 亚洲精品乱码久久久久久黑人 | 久久视频国产精品免费视频在线| 午夜精品一区二区三区在线视| 亚洲视频在线看| 亚洲一区国产一区| 午夜精品久久久久久久99热浪潮| 亚洲一区美女视频在线观看免费| 亚洲一二三四久久| 亚洲砖区区免费| 欧美一区二区在线看| 久久超碰97中文字幕| 欧美在线观看视频一区二区三区 | 亚洲素人一区二区| 亚洲一区观看| 欧美一区影院| 久久综合色88| 欧美精品一区二区久久婷婷| 欧美日韩成人综合| 国产精品免费福利| 国内精品伊人久久久久av一坑| 好吊成人免视频| 亚洲黄页一区| 亚洲伊人网站| 久久综合久久久久88| 欧美91视频| 日韩视频在线观看| 亚洲欧美综合精品久久成人| 久久国产一区二区三区| 欧美成人免费视频| 国产精品久久久久av| 国产一区欧美日韩| 91久久精品美女| 亚洲欧美另类久久久精品2019| 久久精品国内一区二区三区| 欧美成年人视频网站欧美| 亚洲精品麻豆| 亚洲欧美日本国产专区一区| 久久精品一区二区三区四区| 欧美高清在线| 国产伦理一区| 亚洲精品国产无天堂网2021| 亚洲一区二区三区免费在线观看| 久久久av网站| 日韩一级黄色av| 久久蜜桃资源一区二区老牛 | 欧美国产欧美亚洲国产日韩mv天天看完整| 91久久精品国产91久久性色tv| 亚洲一区综合| 欧美国产日韩一二三区| 国产精品欧美日韩久久| 亚洲国产成人tv| 欧美一区二区在线| 亚洲欧洲精品成人久久奇米网| 欧美淫片网站| 国产精品久久久久久久一区探花 | 久久成人精品无人区| 欧美日韩亚洲三区| 亚洲激情电影在线| 久久精品午夜| 亚洲香蕉视频| 欧美久久久久久| 亚洲国产精品久久久| 欧美在线视屏| 这里只有精品丝袜| 欧美电影在线观看完整版| 激情成人在线视频| 久久riav二区三区| 一本久久知道综合久久| 欧美大片在线观看一区| 在线日韩一区二区| 久久精品官网| 亚洲午夜一区二区三区| 欧美日韩不卡一区| 亚洲三级毛片| 欧美激情精品| 麻豆成人91精品二区三区| 国产一区二区三区奇米久涩 | 欧美一区二区三区婷婷月色| 国产精品久久久一区麻豆最新章节 | 亚洲午夜一区| 亚洲激情影院| 欧美精品videossex性护士| 亚洲欧洲日本专区| 亚洲国产另类 国产精品国产免费| 奶水喷射视频一区| 亚洲高清一二三区| 欧美激情一区二区三区在线视频| 久热精品视频| 亚洲欧洲在线观看| 欧美激情1区2区3区| 欧美大尺度在线| 一区二区三区欧美在线观看| 亚洲精品一区在线观看香蕉| 欧美日韩亚洲不卡|