zoukankan      html  css  js  c++  java
  • codeforces A. Jeff and Digits 解题报告

    题目链接: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 }
  • 相关阅读:
    1365 Fib(N) mod Fib(K) [斐波那契相关]
    51nod1439 互质对 [莫比乌斯函数, 容斥]
    UVA1642 魔法GCD Magical GCD [gcd, 双向链表]
    李超线段树学习笔记 [模板]
    P4297 [NOI2006]网络收费 [树形dp]
    田忌赛马 [贪心(完成) / 动态规划(待填坑)]
    菌落 [状压dp?]
    异或约数和 [异或相关]
    java 驼峰命名
    java 静态构造函数
  • 原文地址:https://www.cnblogs.com/windysai/p/3352132.html
Copyright © 2011-2022 走看看