题目: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. JSON对象与JSON字符串之间的转换

    JSON引用包:import net.sf.json 1.JSON字符串转JSON对象(例子中的AgencyExpand是java对象) JSONObject  json = JSONObject.f ...

  2. 基础知识:if条件、while循环、for循环 相关练习

    1.实现用户输入用户名和密码,当用户名为 seven 且 密码为 123 时,显示登陆成功,否则登陆失败! while True: name = input('请输入用户名:') psw = inpu ...

  3. 转载:Django之Form组件

    Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 小试牛刀 1.创建Form类 +? 1 2 3 ...

  4. bootloader的移植

    jz2440开发板 在介绍bootloader里边的内容的时候,需要知道的是: bootloader的引入的目的就是启动linux内核,一个简单的bootloader编写需要以下的步骤: ①初始化硬件 ...

  5. CodeForces - 425E Sereja and Sets 题解

    题目大意: 我们有一个集合 S,其中包含了 m 个不完全相同的区间[l1,r1],[l2,r2]…[lm,rm] (1≤li≤ri≤n,li,ri 都为整数). 定义 f(S)=k,表示集合 S 中能 ...

  6. CSU1217

    就跟数字出现奇数次道理是一样的,将一个数转化为2进制后找出现奇数次个1的位置,最后将其输出来便是出现奇数次的数 #include <cstdio> int main() { int n,a ...

  7. 听dalao讲课 7.26

    XFZ今天讲了些关于多项式求ln和多项式求导以及多项式求积分的东西 作为一个连导数和积分根本就不会的蒟蒻,就像在听天书,所以不得不补点前置知识 1.积分 积分是微积分学与数学分析里的一个核心概念.通常 ...

  8. [JLOI2008]提示问题

    题目描述 最近在JLOI网上的一个流行游戏中,选手要回答很难的问题.假如在规定时间内不能回答,系统将给出1个提示,之后再依次给出第2,3个提示.出现在答案中的是字母和下列字符: '.',',',':' ...

  9. ***mysql 用一个表的一列,去更新另一表的一列

    需求: 老板给了一个EXCEL数据,是本人提供的一个模板,含ID,现在相当于要导入这新增的一列数据到数据库中的某一个表. 方法一:用navicat,在excel中复制一列,再粘贴到navicat中的一 ...

  10. 2017 CCPC 杭州 HDU6265B 积性函数

    题目链接 http://acm.hdu.edu.cn/downloads/CCPC2018-Hangzhou-ProblemSet.pdf B题 数论题      h(n)=∑ d|n φ(d) × ...