经过紫书的分析,已经将问题转化为求组合数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. 一点ASP.NET MVC Html.Helper类的方法

    一点ASP.NET MVC Html.Helper类 这里就只写一个Html.ActionLink()和Html.DropdownList(). Html.ActionLink()里有三个参数,第一个 ...

  2. java集合类(五)About Map

    接上篇“java集合类(四)About Set” 这次学完Map之后,就剩队列的知识,之后有关java集合类的学习就将告一段落,之后可能会有java连接数据库,I/O,多线程,网络编程或Android ...

  3. 【BestCoder】【Round#29】

    T1 啊……a^b 与 c^d比较大小,我们可以两边取对数,转化成 log(a^b)=b*log(a) 和d*log(c) 这样就能直接算了……然后稍微搞一下精度什么的就A了=.= //BC #29 ...

  4. C# 中请求数据方式

    #region 根据URL获取结果集        /// <summary>        /// 根据URL获取结果集 默认为GET,如果数据量大了可以传入POST        // ...

  5. function复习

    #include <iostream> #include <functional> using namespace std; int fun(int a) { std::cou ...

  6. contentType,pageEncoding,charset,setCharacterEncoding

    contentType,pageEncoding,charset,setCharacterEncoding HTML中的meta标签,以及HTTP Header. -------------字符集.字 ...

  7. crud springmvc

    实体类:Student.java package demo.entity; public class Student { private int id; private String name; pr ...

  8. Unity Editor not displaying Android textures properly

    最近入门学习shader,语法倒没什么,有一个奇怪的问题,如果把编译平台从pc转换为android模式的话,如果你的shader 带 Normal Mapping 的 话,效果和android上的真机 ...

  9. unity3d旋转摄像机脚本

    void Update () { )) { if (axes == RotationAxes.MouseXAndY) { // Read the mouse input axis rotationX ...

  10. 【redis】06Redis的高级应用之事务处理、持久化操作、pub_sub、虚拟内存

    上节课详细讲解了redis数据库的常用命令,以及redis数据库高级应用当中的, 安全性,跟咱们的主从复制, 这节课呢,咱们继续来讲咱们的高级应用, 首先来看一下咱们的事务处理, 事务处理 我前面说过 ...