题目:https://www.luogu.org/problemnew/show/P2822

阶乘太大,算不了;

但 k 只有 8 个质因子嘛,暴力60分;

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int const maxn=;
int n,m,t,K,pri[]={,,,,,,,},num[],tp[],pk[],tp2[],tt[];
void gt(int x,int t[])//x
{
for(int i=;i<;i++)
{
t[i]=;
if(x==||x==)continue;
while(x%pri[i]==)x/=pri[i],t[i]++;
}
}
void get(int x,int num[])//x!
{
for(int i=;i<;i++)num[i]=;
if(x==||x==)return;
for(int i=;i<=x;i++)
{
gt(i,tt);
for(int j=;j<;j++)num[j]+=tt[j];
}
}
int main()
{
scanf("%d%d",&t,&K); gt(K,pk);
while(t--)
{
scanf("%d%d",&n,&m); int ans=;
for(int i=;i<=n;i++)
{
get(i,num); memcpy(tp2,num,sizeof num);
for(int j=;j<=min(i,m);j++)
{
get(j,tp);
for(int k=;k<;k++)num[k]-=tp[k];
get(i-j,tp);
bool fl=;
for(int k=;k<;k++)
{
num[k]-=tp[k];
if(num[k]<pk[k]){fl=; break;}
}
if(!fl)ans++;
memcpy(num,tp2,sizeof tp2);
}
}
printf("%d\n",ans);
}
return ;
}

60分

把这个优化一下就能过了;

1.DP,f[i][j] 表示 n <= i , m <= j 的 C(n,m) 中有多少数是 k 的倍数,毕竟 k 是固定的;

2. x! 分解质因子不用枚举,而是那个做法,p倍数有 x / p 个,p2 的倍数有 x / p / p 个...

3.阶乘分解质因子的结果预处理出来,直接调用。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int const maxn=,maxm=1e4+;
int T,K,f[maxn][maxn],pri[]={,,,,,,,},num[],t1[];
int n[maxm],m[maxm],mxn,mxm,s[maxn][];
int rd()
{
int ret=,f=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-; ch=getchar();}
while(ch>=''&&ch<='')ret=(ret<<)+(ret<<)+ch-'',ch=getchar();
return ret*f;
}
void get(int x,int t[],int val)//x
{
for(int i=;i<&&pri[i]<=x;i++)
{
if(x==||x==)return;
while(x%pri[i]==)x/=pri[i],t[i]+=val;
}
}
void getx(int x,int t[],int val)//x!
{
int tmp=x;
for(int i=;i<;i++)
{
x=tmp;
while(x)t[i]+=(x/pri[i])*val,x/=pri[i];
}
}
int work(int x,int y)
{
memset(t1,,sizeof t1);
for(int i=;i<;i++)
{
t1[i]=s[x][i]-s[y][i]-s[x-y][i];
if(t1[i]<num[i])return ;
}
return ;
}
void init()
{
get(K,num,);
for(int i=;i<=mxn;i++)
{
memset(t1,,sizeof t1);
getx(i,t1,); memcpy(s[i],t1,sizeof t1);//阶乘质因子也预处理!
}
for(int i=;i<=mxn;i++)
{
for(int j=;j<=mxm&&j<i;j++)
f[i][j]=f[i-][j]+f[i][j-]-f[i-][j-]+work(i,j);
for(int j=i;j<=mxm;j++)f[i][j]=f[i][j-];
}
}
int main()
{
T=rd(); K=rd();
for(int i=;i<=T;i++)
{
n[i]=rd(); m[i]=rd();
mxn=max(mxn,n[i]); mxm=max(mxm,m[i]);
}
init();
for(int i=;i<=T;i++)printf("%d\n",f[n[i]][m[i]]);
return ;
}

洛谷 P2822 [ NOIP 2017 ] 组合数问题 —— 数学的更多相关文章

  1. 洛谷 P3951 NOIP 2017 小凯的疑惑

    洛谷 P3951 NOIP 2017 小凯的疑惑 题目描述 小凯手中有两种面值的金币,两种面值均为正整数且彼此互素.每种金币小凯都有 无数个.在不找零的情况下,仅凭这两种金币,有些物品他是无法准确支付 ...

  2. 洛谷 P3960 [ NOIP 2017 ] 列队 —— 线段树

    题目:https://www.luogu.org/problemnew/show/P3960 NOIP 题,不用很复杂的数据结构...但又参考了许多: 要求支持维护删除第 k 个和在末尾插入的数据结构 ...

  3. 洛谷 P3953 [ NOIP 2017 ] 逛公园 —— 最短路DP

    题目:https://www.luogu.org/problemnew/show/P3953 主要是看题解...还是觉得好难想啊... dfs DP,剩余容量的损耗是边权减去两点最短路差值...表示对 ...

  4. 【题解】洛谷P2822 [NOIP2016TG ]组合数问题 (二维前缀和+组合数)

    洛谷P2822:https://www.luogu.org/problemnew/show/P2822 思路 由于n和m都多达2000 所以暴力肯定是会WA的 因为整个组合数是不会变的 所以我们想到存 ...

  5. 【noip】跟着洛谷刷noip题2

    noip好难呀. 上一个感觉有点长了,重开一个. 36.Vigenère 密码 粘个Openjudge上的代码 #include<cstdio> #include<iostream& ...

  6. 洛谷模拟NOIP考试反思

    洛谷模拟NOIP考试反思 想法 考了这么简单的试qwq然而依然emmmmmm成绩不好 虽然本次难度应该是大于正常PJ难度的但还是很不理想,离预估分数差很多qwq 于是就有了本反思嘤嘤嘤 比赛链接 原比 ...

  7. 【noip】跟着洛谷刷noip题

    传送门 1.铺地毯 d1t1 模拟 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> # ...

  8. 洛谷P3951 小凯的疑惑 - 数学 /扩展欧几里得

    传送门 题意:求出a和b不能通过线性组合(即n*a+m*b)得到的最大值: 思路:摘自洛谷: 不妨设 a<b 假设答案为 x 若 x≡m*a ( mod b )(1≤m≤b−1) (mod3)什 ...

  9. 洛谷P2835 刻录光盘 [2017年6月计划 强连通分量02]

    P2835 刻录光盘 题目描述 在JSOI2005夏令营快要结束的时候,很多营员提出来要把整个夏令营期间的资料刻录成一张光盘给大家,以便大家回去后继续学习.组委会觉得这个主意不错!可是组委会一时没有足 ...

随机推荐

  1. Bash的循环结构(for和while)

    在bash有三中类型的循环结构表达方法:for,while,until.这里介绍常用的两种:for和while. for bash的for循环表达式和python的for循环表达式风格很像: for ...

  2. Python之机器学习-波斯顿房价预测

    目录 波士顿房价预测 导入模块 获取数据 打印数据 特征选择 散点图矩阵 关联矩阵 训练模型 可视化 波士顿房价预测 导入模块 import pandas as pd import numpy as ...

  3. Jquery validate自定义验证

    http://www.runoob.com/jquery/jquery-plugin-validate.html addMethod(name,method,message)方法 参数 name 是添 ...

  4. 洛谷P3373 线段树2(补上注释了)

    毒瘤题.找了一下午+晚上的BUG,才发现原来query_tree写的是a%p; 真的是一个教训 UPD:2019.6.18 #include<iostream> #include<c ...

  5. Node.js & module system

    Node.js & module system Node.js v10.9.0 Documentation https://nodejs.org/api/modules.html#module ...

  6. bzoj 1962 硬币游戏 (猜数问题)

    [bzoj1962]模型王子 2015年3月26日1,6460 Description Input 输入数据共一行,两个整数N,K,用一个空格隔开,具体意义如题目中所述. Output 输出数据共一行 ...

  7. HDU 5640 King's Cake【模拟】

    题意: 给定长方形,每次从中切去一个最大的正方形,问最终可以得到多少正方形. 分析: 过程类似求gcd,每次减去最小的边即可. 代码: #include <cstdio> #include ...

  8. CLR GC

    一.垃圾回收算法 每个应用程序都包含一组根(root),每个根都是一个存储位置,他要么为null,要么指向托管堆的一个对象,类型中定义的静态字段.局部变量.方法参数等都会被认为是根. 垃圾回收器(GC ...

  9. POJ2632 Crashing Robots 解题报告

    Description In a modernized warehouse, robots are used to fetch the goods. Careful planning is neede ...

  10. hdu——2586 How far away ?

    How far away ? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...