题目: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. 【转载】Raft 为什么是更易理解的分布式一致性算法

    一致性问题可以算是分布式领域的一个圣殿级问题了,关于它的研究可以回溯到几十年前. 拜占庭将军问题 Leslie Lamport 在三十多年前发表的论文<拜占庭将军问题>(参考[1]). 拜 ...

  2. 81-Gator Oscillator,加多摆动指标.(2015.7.1)

    Gator Oscillator 加多摆动指标 Oscillator,加多摆动指标.(2015.7.1)" title="81-Gator Oscillator,加多摆动指标.(2 ...

  3. (转载)Catalan数——卡特兰数

    Catalan数——卡特兰数 今天阿里淘宝笔试中碰到两道组合数学题,感觉非常亲切,但是笔试中失踪推导不出来后来查了下,原来是Catalan数.悲剧啊,现在整理一下 一.Catalan数的定义令h(1) ...

  4. Vue如何mock数据模拟Ajax请求

    我们在做一个项目时前期可能没有后端提供接口模拟数据,那么作为前端就需要自己写json文件模拟数据加载.网上往往参考的都是不全面的,比如get请求没问题但是post请求就报错了.在Vue中只需要vue- ...

  5. ROS 笔记 程序包/节点/topic

    官方教程: wiki.ros.org/cn/ROS/tutorials 程序包打创建于编译 创建程序包 在工作空间的src底下,输入如下命令: $ catkin_create_pkg 要创建的包名 依 ...

  6. bzoj 3173 [Tjoi2013]最长上升子序列 (treap模拟+lis)

    [Tjoi2013]最长上升子序列 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2213  Solved: 1119[Submit][Status] ...

  7. RelativeLayout属性大全

  8. Servlet表单数据处理

    以下内容引用自http://wiki.jikexueyuan.com/project/servlet/form-data.html: 当需要从浏览器到Web服务器传递一些信息并最终传回到后台程序时,一 ...

  9. Jsp+servlet 验证码案例

    昨晚在csdn看到一位前辈写一个ajax+servlet+jsp验证.顿时心血来潮,在阅读前辈的代码下我亲手体验一下,做了一个验证码生成工具类.以供大家做个參考. 1:加入VeriyCodeUtils ...

  10. 【python】glob模块、os模块

    http://www.cnblogs.com/hongten/p/hongten_python_glob.html http://wenku.baidu.com/link?url=AgUq9_yQVj ...