zoukankan      html  css  js  c++  java
  • 数字任意组合

    链接:https://www.nowcoder.com/acm/contest/160/A
    来源:牛客网

    题目描述
    有一个计数器,计数器的初始值为0,每次操作你可以把计数器的值加上a1,a2,...,an中的任意一个整数,操作次数不限(可以为0次),问计数器的值对m取模后有几种可能。
    输入描述:

    第一行两个整数n,m
    接下来一行n个整数表示a1,a2,...,an
    1≤n≤100
    1≤m,a1,a2,...,an≤1000000000

    输出描述:

    输出一个整数表示答案

    输入

    3 6
    6 4 8

    输出


    3

    题意 : 将所给的几个数字任意组合,再将组合出来的数对 M 取模,求模数的种类数

    思路分析 : 解法很巧妙的利用了 gcd , 求一下所有数字的 gcd , 因为是要求个数,再将所求 gcd 与 m 求一次 gcd ,最后 m / gcd 即为答案

        若两个数 gcd 为 1, 则可以通过对一个数取模,拼凑出模数以内的任意数,想一想就明白了

    代码示例 :

    #include <bits/stdc++.h>
    using namespace std;
    const int maxn = 3e5+5;
    #define ll long long
     
    ll a[105];
    ll n, m;
    ll gcd(ll a, ll b) {return b==0?a:gcd(b, a%b); }
    set<ll>s;
     
    int main () {
     
        cin >> n >> m;
        ll g = 0;
        for(ll i = 1; i <= n; i++){
            scanf("%lld", &a[i]);
            g = gcd(g, a[i]);
        }
        ll g2 = gcd(g, m); 
        printf("%lld
    ", m/g2);
        return 0;
    }
    

     Astronaut Natasha arrived on Mars. She knows that the Martians are very poor aliens. To ensure a better life for the Mars citizens, their emperor decided to take tax from every tourist who visited the planet. Natasha is the inhabitant of Earth, therefore she had to pay the tax to enter the territory of Mars.

    There are n
    banknote denominations on Mars: the value of i-th banknote is ai

    . Natasha has an infinite number of banknotes of each denomination.

    Martians have k
    fingers on their hands, so they use a number system with base k. In addition, the Martians consider the digit d (in the number system with base k) divine. Thus, if the last digit in Natasha's tax amount written in the number system with the base k is d

    , the Martians will be happy. Unfortunately, Natasha does not know the Martians' divine digit yet.

    Determine for which values d Natasha can make the Martians happy.

    Natasha can use only her banknotes. Martians don't give her change.
    Input

    The first line contains two integers n
    and k (1≤n≤100000, 2≤k≤100000

    ) — the number of denominations of banknotes and the base of the number system on Mars.

    The second line contains n
    integers a1,a2,…,an (1≤ai≤109

    ) — denominations of banknotes on Mars.

    All numbers are given in decimal notation.
    Output

    On the first line output the number of values d

    for which Natasha can make the Martians happy.

    In the second line, output all these values in increasing order.

    Print all numbers in decimal notation.
    Examples
    Input
    Copy

    2 8
    12 20

    Output
    Copy

    2
    0 4

    Input
    Copy

    3 10
    10 20 30

    Output
    Copy

    1
    0

    Note

    Consider the first test case. It uses the octal number system.

    If you take one banknote with the value of 12
    , you will get 148 in octal system. The last digit is 48

    .

    If you take one banknote with the value of 12
    and one banknote with the value of 20, the total value will be 32. In the octal system, it is 408. The last digit is 08

    .

    If you take two banknotes with the value of 20
    , the total value will be 40, this is 508 in the octal system. The last digit is 08

    .

    No other digits other than 08
    and 48 can be obtained. Digits 08 and 48

    could also be obtained in other ways.

    The second test case uses the decimal number system. The nominals of all banknotes end with zero, so Natasha can give the Martians only the amount whose decimal notation also ends with zero.

    题意 :基本同上面的题,只不过数据范围不太一样,并且此题需要输出不同的模数是什么
    思路分析 :基本同上,加个 set 即可

    代码示例 :

    #include <bits/stdc++.h>
    using namespace std;
    const int maxn = 3e5+5;
    #define ll long long
     
    ll n, k;
    ll gcd(ll a, ll b) {return b==0?a:gcd(b, a%b); }
    set<ll>s;
     
    int main () {
        ll x;
        
        cin >> n >> k;
        ll g = 0;
        for(ll i = 1; i <= n; i++){
            scanf("%lld", &x);
            g = gcd(g, x);
        }
        for(ll i = 0, j = 0; i <= k; i++, j += g){
            s.insert(j%k);
        }
        printf("%d
    ", s.size());
        set<ll>:: iterator it;
        
        for(it = s.begin(); it != s.end(); it++) {
            printf("%d ", *it); 
        }
        return 0;
    }
    
    东北日出西边雨 道是无情却有情
  • 相关阅读:
    非确定的自动机NFA确定化为DFA--作业8
    正规式到正规文法与自动机--作业7
    正规文法与正规式--作业六
    词法分析程序的设计与实现--作业五
    文法和语文总结与梳理--作业4
    语法树,短语,直接短语,句柄--作业
    文法和语言--作业
    作业-编译原理概述
    js实现线性结构转树形结构(生成无限层级菜单)
    基于PriorityQueue(优先队列)解决TOP-K问题
  • 原文地址:https://www.cnblogs.com/ccut-ry/p/9495472.html
Copyright © 2011-2022 走看看