经过紫书的分析,已经将问题转化为求组合数C(n-1, 0)~C(n-1, n-1)中能够被m整除的个数,并输出编号(这n个数的编号从1开始)

首先将m分解质因数,然后记录下每个质因子对应的指数。

由组合恒等式,我们可以递推C(n, k)的质因数的个数。

一个没什么用的小优化:因为杨辉三角每一行都是对称的,所以我们可以求出前一半答案,然后根据对称性求出后一半的答案。

需要注意的是,如果答案中有类似C(10, 5)的数,就不要再对称了,会重复的。

这个优化貌似也只能优化0.05s左右。

 #include <cstdio>
#include <cstring>
#include <cmath> const int maxn = + ;
int prime[maxn], bad[maxn], e[maxn], ans[maxn];
int p_cnt; void prime_factors(int n)
{
p_cnt = ;
int m = floor(sqrt(n) + 0.5);
for(int i = ; i <= m; ++i)
{
if(n % i == ) { prime[p_cnt++] = i; }
while(n % i ==) { e[p_cnt-]++; n /= i; }
}
if(n > )
{
prime[p_cnt] = n;
e[p_cnt++] = ;
}
} int main()
{
int n, m;
while(scanf("%d%d", &n, &m) == )
{
memset(prime, , sizeof(prime));
memset(bad, , sizeof(bad));
memset(ans, , sizeof(ans));
memset(e, , sizeof(e));
n--; prime_factors(m);
for(int i = ; i < p_cnt; ++i)
{
int p = prime[i];
int need = e[i];
int cur_e = ;
for(int k = ; k <= n/; ++k)
{
int x = n - k + ;
while(x % p == ) { cur_e++; x /= p; }
x = k;
while(x % p == ) { cur_e--; x /= p; }
if(cur_e < need) bad[k] = ;
}
} int ans_cnt = ;
for(int k = ; k <= n/; ++k)
if(!bad[k]) ans[ans_cnt++] = k;
if(ans_cnt)
{
int p = ans_cnt-;
if(ans[p] * == n) p--;
for(int i = p; i >= ; i--)
ans[ans_cnt++] = n - ans[i];
printf("%d\n", ans_cnt);
printf("%d", ans[] + );
for(int i = ; i < ans_cnt; ++i) printf(" %d", ans[i] + );
}
else puts("");
printf("\n");
} return ;
}

代码君

UVa 1635 (唯一分解定理) Irrelevant Elements的更多相关文章

  1. UVa 10375 (唯一分解定理) Choose and divide

    题意: 求组合数C(p, q) / C(r, s)结果保留5为小数. 分析: 先用筛法求出10000以内的质数,然后计算每个素数对应的指数,最后再根据指数计算答案. #include <cstd ...

  2. UVA 10791 -唯一分解定理的应用

    #include<iostream> #include<stdio.h> #include<algorithm> #include<string.h> ...

  3. UVA - 11388 唯一分解定理

    题意:给出G和L,求最小的a使得gcd(a,b)=G,lcm(a,b)=L 显然a>=G,所以a取G,b要满足质因子质数为L的同次数,b取L //此处应有代码

  4. UVA - 10780 唯一分解定理

    白书P171 对m,n!分解,质因子指数取min #include<iostream> #include<algorithm> #include<cstdio> # ...

  5. Irrelevant Elements UVA - 1635 二项式定理+组合数公式+素数筛+唯一分解定理

    /** 题目:Irrelevant Elements UVA - 1635 链接:https://vjudge.net/problem/UVA-1635 题意:給定n,m;題意抽象成(a+b)^(n- ...

  6. UVA - 10375 Choose and divide[唯一分解定理]

    UVA - 10375 Choose and divide Choose and divide Time Limit: 1000MS   Memory Limit: 65536K Total Subm ...

  7. UVA.10791 Minimum Sum LCM (唯一分解定理)

    UVA.10791 Minimum Sum LCM (唯一分解定理) 题意分析 也是利用唯一分解定理,但是要注意,分解的时候要循环(sqrt(num+1))次,并要对最后的num结果进行判断. 代码总 ...

  8. POJ2167Irrelevant Elements[唯一分解定理 组合数 杨辉三角]

    Irrelevant Elements Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 2407   Accepted: 59 ...

  9. UVA 10375 Choose and divide【唯一分解定理】

    题意:求C(p,q)/C(r,s),4个数均小于10000,答案不大于10^8 思路:根据答案的范围猜测,不需要使用高精度.根据唯一分解定理,每一个数都可以分解成若干素数相乘.先求出10000以内的所 ...

随机推荐

  1. word小技巧

    如何将英文和数字替换为times new romans 1,点击替换(ctrl+H) .2,在查找内容中输入”([A-Z0-9])“(不包括引号,但包括小括号),这是替换所有大写字母和数字,如果还想替 ...

  2. 数据库SQLiteDatabase

    package com.baclock.entity; import android.provider.BaseColumns; /** * Created by Jack on 5/4/2016. ...

  3. sqlserver 2008r2 表分区拆分问题

    问题描述: 对tab1表实行自动天分区,每天通过sqlserver代理-作业00:00点自动生成分区: 因有次停了数据库服务,sqlserver 代理服务忘记开启,导致当天00:00没有生成新分区: ...

  4. OI 回忆录

    时间过得好快,一下子就高三了,一下子就退役了,两年的时间仿佛就在一眨眼的功夫内度过了.不过还是想回忆回忆这两年的雨雪风霜,也就当做个总结吧. 高一其实并没有什么好说的,反正就这么颓到了高二. 高二上学 ...

  5. Tutorial: Model

    What is a model? Across the internet the definition of MVC is so diluted that it's hard to tell what ...

  6. windows下安装ubantu

        首先声明我是一个linux大菜鸟,之所以学这个,一个是好玩,另外做DL的一些软件如Caffe要在这个平台上运行,所以没事就鼓捣鼓捣.linux是一种内核,市场上支持这种内核的操作系统有uban ...

  7. JAVA:23种设计模式详解(转)2

    我们接着讨论设计模式,上篇文章我讲完了5种创建型模式,这章开始,我将讲下7种结构型模式:适配器模式.装饰模式.代理模式.外观模式.桥接模式.组合模式.享元模式.其中对象的适配器模式是各种模式的起源,我 ...

  8. Spring + JMS + ActiveMQ实现简单的消息队列(监听器异步实现)

    首先声明:以下内容均是在网上找别人的博客综合学习而成的,可能会发现某些代码与其他博主的相同,由于参考的文章比较多,这里对你们表示感谢,就不一一列举,如果有侵权的地方,请通知我,我可以把该文章删除. 1 ...

  9. ScannerDemo------string int

    import java.util.Scanner;                                                /** *Scanner演示 */ public cl ...

  10. 一个酷炫的,基于HTML5,Jquery和Css的全屏焦点图特效,兼容各种浏览器

    基于HTML5和CSS的焦点图特效,梅花图案的背景很有中国特色,而且还会动哦,效果超炫,推荐下载! 演示图 html代码 <!DOCTYPE html PUBLIC "-//W3C// ...