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

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>
            亚洲女同同性videoxma| 亚洲激情国产精品| 亚洲一区制服诱惑| 夜夜嗨av一区二区三区网站四季av | 久久久久久一区二区三区| 中文亚洲免费| 国产欧美1区2区3区| 久久久久国色av免费观看性色| 亚洲日本中文| 欧美日韩精品福利| 亚洲一区欧美一区| 久久精品视频导航| 亚洲伦理自拍| 亚洲欧美日韩精品久久奇米色影视| 欧美日韩亚洲不卡| 欧美一区二区三区四区在线| 亚洲女人天堂成人av在线| 国产婷婷精品| 亚洲国产精品久久久久| 国产精品激情| 免费日韩成人| 国产精品久久久久91| 欧美在线免费视频| 欧美jizzhd精品欧美喷水| 午夜精品成人在线| 美女精品自拍一二三四| 午夜精品久久久久久久99黑人| 午夜在线精品偷拍| 99国产精品视频免费观看一公开| 亚洲调教视频在线观看| 亚洲欧洲日韩综合二区| 香蕉久久久久久久av网站| 亚洲国产91色在线| 中文欧美字幕免费| 日韩一区二区电影网| 欧美在线视屏| 欧美一区二区三区免费在线看| 久久久水蜜桃| 久久精品30| 国产精品美女主播| 亚洲美女色禁图| 亚洲国产精品久久久久婷婷老年| 亚洲丝袜av一区| 一区二区动漫| 久久国产一区二区| 国产精品分类| 一区二区三区四区国产| 亚洲日本成人| 蜜桃av综合| 另类尿喷潮videofree| 国产精品天天摸av网| 日韩手机在线导航| 亚洲精品日韩激情在线电影| 久久久999| 久久艳片www.17c.com| 国产日韩欧美综合一区| 亚洲女同在线| 久久精品国产成人| 国产手机视频一区二区| 亚洲一区久久久| 午夜精品一区二区三区电影天堂 | 国产精品日日做人人爱| 亚洲视频国产视频| 亚洲一区二区三区涩| 欧美日韩综合不卡| 99精品欧美一区| 亚久久调教视频| 国产精品成人一区二区| 91久久国产自产拍夜夜嗨| 最新日韩欧美| 欧美精品一区二区三区蜜桃| 亚洲国产一区在线| 99这里只有精品| 国产精品九九久久久久久久| 99精品视频免费观看视频| 亚洲一区免费视频| 国产精品萝li| 久久精品国产精品亚洲| 嫩模写真一区二区三区三州| 亚洲黄色在线看| 欧美另类99xxxxx| 一区二区福利| 久久电影一区| 亚洲区一区二区三区| 欧美激情综合亚洲一二区| 一区二区三区日韩精品视频| 欧美一级久久| 亚洲理伦电影| 亚洲精品视频在线看| 亚洲最新视频在线| 国产精品日韩精品| 久久久久久亚洲综合影院红桃| 男女精品视频| 亚洲一区二区三区四区五区黄| 国产精品系列在线| 久久亚洲综合| 亚洲一区二区三区在线播放| 久久一二三区| 亚洲五月六月| 原创国产精品91| 国产精品爱久久久久久久| 欧美在线影院在线视频| 亚洲精品国产品国语在线app| 午夜精品久久| 亚洲精品五月天| 国产日韩欧美一区| 欧美日韩精品久久| 久久成人国产| 亚洲午夜影视影院在线观看| 亚洲欧美一区二区原创| 一本久久a久久免费精品不卡| 亚洲欧美日韩精品在线| 精品动漫3d一区二区三区免费版 | 午夜精彩视频在线观看不卡 | 亚洲欧美在线一区| 欧美激情va永久在线播放| 日韩一级欧洲| 亚洲电影免费在线观看| 国产精品一级二级三级| 欧美精品久久久久久久| 久久九九电影| 亚洲欧美在线另类| 99在线精品免费视频九九视| 欧美激情视频一区二区三区在线播放| 欧美一区高清| 国产精品一卡二| 久久中文在线| 香蕉av777xxx色综合一区| 亚洲国产美女精品久久久久∴| 欧美一级电影久久| 亚洲免费影视| 亚洲免费综合| 亚洲综合精品四区| 亚洲午夜在线| 这里是久久伊人| 99精品国产热久久91蜜凸| 1204国产成人精品视频| 精品va天堂亚洲国产| 国产美女一区二区| 欧美视频三区在线播放| 欧美性生交xxxxx久久久| 欧美日韩在线播放一区| 欧美日韩免费观看一区=区三区| 欧美高清成人| 欧美日韩免费视频| 欧美四级电影网站| 国产精品电影网站| 国产精品影院在线观看| 国产午夜精品视频| 欧美日韩综合另类| 久久久久亚洲综合| 久久久久九九视频| 美女精品视频一区| 欧美成年网站| 欧美日韩国产成人在线| 欧美日韩免费在线视频| 国产精品国产三级国产aⅴ入口 | 国产日产欧美精品| 国产婷婷色综合av蜜臀av| 一区二区三区在线免费播放| 亚洲国产精品123| 99国产欧美久久久精品| 亚洲一区二区不卡免费| 欧美一区二区三区免费视频| 久久精品人人| 亚洲黄一区二区三区| av不卡在线| 久久av老司机精品网站导航| 免费成人av在线看| 国产精品v欧美精品∨日韩| 国产精品高潮呻吟久久av黑人| 欧美日韩成人综合在线一区二区| 欧美午夜激情视频| 好看的日韩av电影| 亚洲最新在线| 久久精品午夜| 日韩视频一区二区在线观看 | 欧美成人精品h版在线观看| 亚洲免费激情| 久久精品盗摄| 欧美日韩日韩| 亚洲国产午夜| 久久精品视频在线播放| 亚洲人成在线影院| 久久er精品视频| 欧美视频日韩视频在线观看| 在线观看日韩专区| 午夜精品久久久久久久久久久久| 免费的成人av| 亚洲欧美日韩中文视频| 欧美成人免费视频| 国内精品久久久久久久果冻传媒 | 亚洲美女黄网| 嫩模写真一区二区三区三州| 亚洲视频一区在线观看| 欧美不卡视频| 在线观看欧美亚洲| 久久国产精品久久久| 99精品免费视频| 欧美精品粉嫩高潮一区二区|