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

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 閱讀(2122) 評(píng)論(3)  編輯 收藏 引用 所屬分類(lèi): 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>
            亚洲精品一二区| 欧美国产视频在线观看| 亚洲精品日韩在线| 国产美女精品视频| 欧美日韩精品免费在线观看视频| 欧美中文字幕不卡| 亚洲深夜影院| 亚洲精品一级| 亚洲电影在线| 免费日韩av片| 久久天堂国产精品| 久久er精品视频| 亚洲欧美日韩国产精品| 日韩系列欧美系列| 最新69国产成人精品视频免费| 国产自产精品| 国模精品一区二区三区| 国产欧美日韩免费| 国产精品欧美一区二区三区奶水| 欧美日韩一二三区| 欧美欧美全黄| 欧美日韩亚洲一区二区三区| 欧美电影免费观看大全| 狼人社综合社区| 久久亚洲国产精品日日av夜夜| 久久riav二区三区| 欧美一区二区三区视频在线观看| 亚洲一区三区电影在线观看| 一区二区三区精密机械公司 | 亚洲成人中文| 欧美大片18| 欧美国产日韩xxxxx| 欧美成人免费网站| 欧美韩日一区| 亚洲日本在线视频观看| 亚洲精品乱码久久久久久蜜桃91| 亚洲高清视频在线| 亚洲区第一页| 99在线热播精品免费99热| 亚洲免费成人av| 日韩视频在线观看| 亚洲无线一线二线三线区别av| 中文欧美日韩| 亚洲欧美日韩在线综合| 亚洲欧美精品伊人久久| 欧美亚洲一级| 久久久久在线观看| 嫩草伊人久久精品少妇av杨幂| 欧美激情第10页| 欧美视频日韩| 国产欧美日韩一级| 影音先锋一区| 日韩视频免费在线| 亚洲欧美日韩精品久久久久| 欧美在现视频| 欧美成人一区二区| 亚洲精选中文字幕| 亚洲女同在线| 老司机精品导航| 欧美日韩一区二区在线观看 | 一区二区欧美精品| 午夜在线一区| 牛牛国产精品| 欧美午夜免费电影| 国产综合欧美在线看| 亚洲精品影视| 亚洲欧美日韩精品| 男人的天堂亚洲| 一区二区三区不卡视频在线观看 | 欧美日韩伦理在线| 国产精品一区二区三区免费观看| 狠狠色丁香婷综合久久| 亚洲日韩中文字幕在线播放| 亚洲欧美日韩精品在线| 美女被久久久| 在线视频日本亚洲性| 久久久精品视频成人| 欧美日韩另类字幕中文| 国户精品久久久久久久久久久不卡| 亚洲黄色在线看| 欧美亚洲在线| 亚洲福利视频免费观看| 亚洲欧美中文字幕| 欧美另类一区| 黄色精品一二区| 亚洲午夜91| 欧美福利网址| 欧美一区亚洲| 国产精品豆花视频| 亚洲欧洲视频| 久久婷婷色综合| 亚洲网站在线观看| 欧美国产精品劲爆| 国内精品视频666| 亚洲欧美国产高清va在线播| 欧美大片免费久久精品三p| 亚洲欧美日韩第一区| 欧美日韩国产综合视频在线观看| 在线观看一区二区精品视频| 欧美一二三视频| 亚洲毛片网站| 欧美成ee人免费视频| 红桃视频国产精品| 欧美一区二区在线看| 日韩亚洲欧美在线观看| 免费在线播放第一区高清av| 国产在线视频不卡二| 亚洲欧美日韩爽爽影院| 日韩一级在线| 欧美激情欧美激情在线五月| 伊人成综合网伊人222| 久久精品国产精品 | 欧美亚洲在线播放| 国产精品v欧美精品∨日韩| 亚洲另类视频| 欧美激情视频一区二区三区在线播放| 西西裸体人体做爰大胆久久久| 欧美性一二三区| 亚洲午夜精品福利| 亚洲免费av片| 欧美日韩精品综合在线| 9色精品在线| 亚洲人成高清| 欧美精品福利| 99在线精品观看| 亚洲人成啪啪网站| 欧美日韩高清免费| 一本色道久久综合一区| 亚洲人成网站777色婷婷| 欧美精品亚洲一区二区在线播放| 亚洲精品综合| 亚洲久久视频| 欧美午夜精品久久久久免费视| 亚洲视频免费| 国产精品99久久99久久久二8| 欧美日韩中文字幕| 亚洲欧美另类中文字幕| 亚洲影音先锋| 国产曰批免费观看久久久| 久久久久成人精品| 狼人天天伊人久久| 日韩视频一区二区三区在线播放| 亚洲欧洲精品天堂一级| 欧美日韩国产精品| 亚洲欧美三级在线| 午夜免费在线观看精品视频| 狠狠色丁香久久综合频道 | 欧美日韩国产经典色站一区二区三区| 99精品视频免费在线观看| av成人黄色| 国产亚洲电影| 免费黄网站欧美| 欧美成人免费观看| 亚洲男人的天堂在线| 性欧美大战久久久久久久免费观看 | 亚洲欧美综合网| 欧美一区网站| 最新亚洲电影| 中文精品视频| 好男人免费精品视频| 亚洲风情亚aⅴ在线发布| 欧美午夜不卡| 久久久av网站| 欧美精品自拍| 久久国产精品一区二区三区四区| 久久久久国产精品www| 9久草视频在线视频精品| 亚洲一区免费观看| 亚洲国产精品嫩草影院| av成人福利| 在线免费观看日韩欧美| 日韩视频免费在线观看| 国产一区二区丝袜高跟鞋图片| 欧美国产日本在线| 国产精品视频网址| 欧美国产精品v| 国产精品一二三四| 欧美激情一区三区| 国产精品一区免费在线观看| 欧美国产91| 国产麻豆综合| 亚洲三级性片| 在线成人免费视频| 亚洲天堂av电影| 亚洲看片免费| 久久久国产精彩视频美女艺术照福利| 中文av字幕一区| 久久视频在线视频| 欧美在线免费观看| 欧美日韩国产首页| 欧美福利网址| 国产在线观看91精品一区| 一本到12不卡视频在线dvd| 亚洲第一精品在线| 性8sex亚洲区入口| 亚洲永久字幕| 欧美区一区二| 欧美激情一区二区在线| 激情成人av| 先锋影音国产精品|