题目链接:http://codeforces.com/problemset/problem/352/A
题目意思:给定一个只有0或5组成的序列,你要重新编排这个序列(当然你可以不取尽这些数字),使得这个序列尽可能地大,并且能被90除尽。
做这道题目,是多次调试本场比赛的B,完全不成功后回头再做的,一开始什么思路都没有,因为觉得是考纯数学,直接看B......怎么说,很大程度是靠直觉的。只知道,这个序列肯定是这种形式:5xx...0 或者像题目所说的特殊情况:0(不过前提是0的个数不为0)。其他就不得而知了。然后在纸上比划了下,发现能被90除尽的序列,5的个数必须满足是9的倍数:9,18... 。至于如何证明,就希望聪明的读者指导一下了。
1 #include <iostream> 2 #include <cstdio> 3 #include <cstdlib> 4 #include <cstring> 5 using namespace std; 6 7 int cnt[10]; // 统计0和5的个数 8 9 int main() 10 { 11 int i, n, tmp, flag; 12 while (scanf("%d", &n) != EOF) 13 { 14 memset(cnt, 0, sizeof(cnt)); 15 for (i = 0; i < n; i++) 16 { 17 scanf("%d", &tmp); 18 cnt[tmp]++; 19 } 20 flag = 0; 21 int len = cnt[5] / 9; 22 // printf("len = %d\n", len); 23 if (len >= 1 && cnt[0] != 0) // 必须两个条件同时满足,这个序列5的个数是9的倍数,且保证个位数必须为0 24 { 25 flag = 1; 26 for (i = 0; i < len * 9; i++) 27 printf("5"); 28 for (i = 0; i < cnt[0]; i++) 29 printf("0"); 30 printf("\n"); 31 } 32 if (!flag && cnt[0] == 0) 33 printf("-1\n"); 34 else if (!flag && cnt[0] != 0) // 题目认为0也能被90除尽 35 printf("0\n"); 36 } 37 return 0; 38 }