【UVa1635】Irrelevant Elements - 唯一分解定理

题意

给你 \(n\) 个数,每次求出相邻两个数的和组成新数列。经过 \(n-1\) 次操作后,得到一个数。求这个数 \(mod \ m\) 与哪些项无关。
如:当 \(m=2 \ , \ n=2\) 时 \(a_1 \ , \ a_2 , a_3 \Rightarrow a_1+a_2 \ , \ a_2+a_3 \Rightarrow \ a_1+2a_2+a_3\) 则与 \(a_2\) 无关

思路

由二项式定理知道结果系数是杨辉三角的第 \(n-1\) 行,问题转换成判断有多少个 \(C_{n-1}^{i}\) 可以整除 \(m\)。
考虑 \(m\) 与 \(C_{n-1}^{i}\) 的唯一分解,\(\prod_{i=1}^n fac_i^{index_i}\) 与 \(C_{n-1}^{i}\) 作比较,当所有的质因子都在 \(C_{n-1}^{i}\) 中出现并且次数都小于 \(C_{n-1}^{i}\) 的次数时,即可整除。
分解 \(C_{n}^{i}\) 时需要用到组合数的递推式:\(C_{n}^{i}=\frac{n-i+1}{i} \times C_{n}^{i-1}\)。分解时只考虑 \(\frac{n-i+1}{i}\),因为 \(C_{n}^{i-1}\) 在上一次中计算过了。

/************************************************
*Author        :  lrj124
*Created Time  :  2019.08.09.21:03
*Mail          :  [email protected]
*Problem       :  uva1635
************************************************/
#include <bits/stdc++.h>
using namespace std;
const int maxn = 100000 + 10;
int n,m,m_index[maxn],factor[maxn],cnt,c_index[maxn],ans[maxn];
inline void init() {
    for (int i = 2;i*i <= m;i++)
        if (!(m%i)) {
            factor[++cnt] = i;
            for (;!(m%i);m /= i,m_index[cnt]++);
        }
    if (m > 1) {
        factor[++cnt] = m;
        m_index[cnt]++;
    }
}
inline bool check(int N,int k) {
    N = N-k+1;
    for (int i = 1;i <= cnt;i++) {
        for (;!(N%factor[i]);N /= factor[i],c_index[i]++);
        for (;!(k%factor[i]);k /= factor[i],c_index[i]--);
    }
    for (int i = 1;i <= cnt;i++)
        if (m_index[i] > c_index[i]) return false;
    return true;
}
int main() {
    //freopen("uva1635.in","r",stdin);
    //freopen("uva1635.out","w",stdout);
    while (cin >> n >> m) {
        memset(m_index,0,sizeof(m_index));
        memset(c_index,0,sizeof(c_index));
        ans[0] = cnt = 0;
        init();
        for (int i = 1;i <= n-2;i++)
            if (check(n-1,i)) ans[++ans[0]] = i+1;
        printf("%d\n",ans[0]);
        for (int i = 1;i <= ans[0];i++) printf("%s%d",i ^ 1 ? " " : "",ans[i]);
        printf("\n");
    }
    return 0;
}

原文地址:https://www.cnblogs.com/lrj124/p/11332077.html

时间: 2024-10-08 02:54:29

【UVa1635】Irrelevant Elements - 唯一分解定理的相关文章

uva1635 Irrelevant Elements(唯一分解定理)

题目链接:点击打开链接 题意:给定n个数a1,a2····an,依次求出相邻两个数值和,将得到一个新数列,重复上述操作,最后结果将变为一个数,问这个数除以m的余数与那些数无关?例如n=3,m=2时,第一次得到a1+a2,a2+a3,在求和得到a1+2*a2+a3,它除以2的余数和a2无关.1=<n<=10^5, 2=<m<=10^9 解题思路: 1.首先我们可以发现对于给定的n其实每项的系数就是C(n-1,i-1),所以我们只需要找到每项的系数对m取余是否为0即可 2.由于m的取值

UVa 1635 Irrelevant Elements (唯一分解定理 || 组合数学)

题目 题目大意 对于给定的\(n\)个数\(a_1\), \(a_2\), ···, \(a_n\), 依次求出相邻两数之和, 将得到一个新数列.重复上述操作, 最后结果将变成一个数.问这个数除以\(m\)的余数将与哪些数无关? 例如\(n = 3\), \(m = 2\)时, 第一次求和得到\(a_1 + a_2\), \(a_2 + a_3\), 再求和得到\(a_1 + 2a_2 + a_3\), 它除以\(2\)的余数和\(a_2\)无关.\(1 ≤ n ≤ 10^5\), \(2 ≤

UVa1635 - Irrelevant Elements(质因数分解)

Young cryptoanalyst Georgie is investigating different schemes of generating random integer numbers ranging from 0 to m - 1. He thinks that standard random number generators are not good enough, so he has invented his own scheme that is intended to b

UVa1635 - Irrelevant Elements

通过观察发现其规律符合杨辉三角 需要注意的是最后ai的系数是C(i-1,n-1) 那么,问题就可以变成判断C(0,n-1),C(1,n-1)....C(n-1,n-1)哪些是m的倍数 只需要计算出m的唯一分解式中各个素因子在C(i-1,n-1)中的指数即可完成判断 然而为了节省时间,实际上我们只需算出m的每一个素因子在C(i-1,n-1)项中  含有几个即可 即我们将c(i-1,n-1)依次除以m的每一个素因子,直到无法整出,即可得出该项素因子的个数 紫薯上给出一个公式C(k,n)=(n-k+1

UVa1635 - Irrelevant Elements(组合数)

题意:整个式子的和可以  化简为  sigma (C(n-1,i-1)*ai) 思路:只要判断C(n-1,i-1)能否被 m整除即可. 做法是先分解m的质因数,然后计算1!~(n-1)!  包含m的质因数的个数 C(n-1,i-1) = (n-1)!/((i-1)!*(n-i)!) 只要判断 剩下的质因数的个数是否大于等于m的任一个质因数的个数即可 <pre name="code" class="cpp">#include<iostream>

组合数杨辉三角(Irrelevant Elements uva1635)

Young cryptoanalyst Georgie is investigating different schemes of generating random integer numbersranging from 0 to m - 1. He thinks that standard random number generators are not good enough, sohe has invented his own scheme that is intended to bri

【组合数的唯一分解定理】Uva1635

给出n.m,求得最终求和数列an=C(n-1,0)*x1 + C(n-1,1)*x2+...+C(n-1,n-1)*xn; 若xi与m无关,则an除以m的余数与xi无关,即余数不含xi的项: 输入:n,m 输出:ans  //无关项的总数: xi1 xi2 ...  //无关项,升序 Tips: 对于组合数的唯一分解定理 由于10^5级别的组合数必然会存在很大的项(long long甚至double都无法保存),要求得其唯一分解式只能采取按递推式分步分解,代码如下: bool check(int

Irrelevant Elements UVA-1635 (二项式定理)

vjudge链接 原题链接 乍一看似乎没什么思路,但是写几个简单的例子之后规律就变得很明显. 比如当 n=5 时,每一步计算后的结果如下: a1 a1+a2 a1+2a2+a3 a1+3a2+3a3+a4 a1+4a2+6a3+4a4+a5 显然系数"1, 4, 6, 4, 1"就是杨辉三角第五行. 故某一项的系数是否是题中 m 的倍数,就决定了最终得到的数除以 n 的余数和那一项是否有关. 二项式定理: 从中很容易得到前后两项的关系 C(n, k)=(n-k+1)/k*C(n, k-

HDU 1452 Happy 2004(唯一分解定理)

题目链接:传送门 题意: 求2004^x的所有约数的和. 分析: 由唯一分解定理可知 x=p1^a1*p2^a2*...*pn^an 那么其约数和 sum = (p1^0+p1^1^-+p1^a1)*-* (pn^0+pn^1^-+pn ) 代码如下: #include <iostream> #include <cstring> #include <algorithm> #include <cstdio> using namespace std; const