洛谷 P2822 [ NOIP 2017 ] 组合数问题 —— 数学
题目: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! 分解质因子不用枚举,而是那个做法,p1 倍数有 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 ] 组合数问题 —— 数学的更多相关文章
- 洛谷 P3951 NOIP 2017 小凯的疑惑
洛谷 P3951 NOIP 2017 小凯的疑惑 题目描述 小凯手中有两种面值的金币,两种面值均为正整数且彼此互素.每种金币小凯都有 无数个.在不找零的情况下,仅凭这两种金币,有些物品他是无法准确支付 ...
- 洛谷 P3960 [ NOIP 2017 ] 列队 —— 线段树
题目:https://www.luogu.org/problemnew/show/P3960 NOIP 题,不用很复杂的数据结构...但又参考了许多: 要求支持维护删除第 k 个和在末尾插入的数据结构 ...
- 洛谷 P3953 [ NOIP 2017 ] 逛公园 —— 最短路DP
题目:https://www.luogu.org/problemnew/show/P3953 主要是看题解...还是觉得好难想啊... dfs DP,剩余容量的损耗是边权减去两点最短路差值...表示对 ...
- 【题解】洛谷P2822 [NOIP2016TG ]组合数问题 (二维前缀和+组合数)
洛谷P2822:https://www.luogu.org/problemnew/show/P2822 思路 由于n和m都多达2000 所以暴力肯定是会WA的 因为整个组合数是不会变的 所以我们想到存 ...
- 【noip】跟着洛谷刷noip题2
noip好难呀. 上一个感觉有点长了,重开一个. 36.Vigenère 密码 粘个Openjudge上的代码 #include<cstdio> #include<iostream& ...
- 洛谷模拟NOIP考试反思
洛谷模拟NOIP考试反思 想法 考了这么简单的试qwq然而依然emmmmmm成绩不好 虽然本次难度应该是大于正常PJ难度的但还是很不理想,离预估分数差很多qwq 于是就有了本反思嘤嘤嘤 比赛链接 原比 ...
- 【noip】跟着洛谷刷noip题
传送门 1.铺地毯 d1t1 模拟 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> # ...
- 洛谷P3951 小凯的疑惑 - 数学 /扩展欧几里得
传送门 题意:求出a和b不能通过线性组合(即n*a+m*b)得到的最大值: 思路:摘自洛谷: 不妨设 a<b 假设答案为 x 若 x≡m*a ( mod b )(1≤m≤b−1) (mod3)什 ...
- 洛谷P2835 刻录光盘 [2017年6月计划 强连通分量02]
P2835 刻录光盘 题目描述 在JSOI2005夏令营快要结束的时候,很多营员提出来要把整个夏令营期间的资料刻录成一张光盘给大家,以便大家回去后继续学习.组委会觉得这个主意不错!可是组委会一时没有足 ...
随机推荐
- C#DateTimeFormatInfo类
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAzAAAACdCAIAAADkAArhAAAgAElEQVR4nO1dWXbjug7UzrI0LS1L0/ ...
- 【HDU 2196】 Computer(树的直径)
[HDU 2196] Computer(树的直径) 题链http://acm.hdu.edu.cn/showproblem.php?pid=2196 这题可以用树形DP解决,自然也可以用最直观的方法解 ...
- git clone问题
中秋节回来上班 竟然忘记带电脑了  ̄□ ̄||还好同事有备用电脑,这要是回去拿估计上午都不用干什么了,用同事电脑当然需要安装环境,下面说一下git上遇到的问题吧 (1)首先我尝试用https方式克隆代码 ...
- React & search & keyboard ghost
React & search & keyboard ghost DOM events https://www.w3schools.com/jsref/dom_obj_event.asp ...
- C#高级编程第9版 第一章 .NET体系结构 读后笔记
.NET的CLR把源代码编译为IL,然后又把IL编译为平台专用代码. IL总是即时编译的,这一点的理解上虽然明白.当用户操作C#开发的软件时,应该是操作已经编译好的程序.那么此时安装在客户机上的程序是 ...
- ZOJ - 3829 Known Notation(模拟+贪心)
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3829 给定一个字符串(只包含数字和星号)可以在字符串的任意位置添加一个数字 ...
- World is Exploding 树状数组+离散化
Given a sequence A with length n,count how many quadruple (a,b,c,d) satisfies: a≠b≠c≠d,1≤a<b≤n,1≤ ...
- POJ 3268_Silver Cow Party
题意: n个地方,标号1~n,每个地方都有一头牛,现在要他们都去往标号为x的地方,再从x返回,每条道路都是单向的,求所有牛走的来回的最短路中的最大值. 分析: 注意在求每头牛走到x时,挨个算肯定超时, ...
- SPOJ SUMPRO(数学)
题意: 给出一个数N,问所有满足n/x=y(此处为整除)的所有x*y的总和是多少.对答案mod(1e9+7). 1 <= T <= 500. 1 <= N <= 1e9. 分析 ...
- NOIP 2010 关押罪犯
P1525 关押罪犯 题目描述 SS 城现有两座监狱,一共关押着 NN 名罪犯,编号分别为 1-N1−N .他们之间的关系自然也极不和谐.很多罪犯之间甚至积怨已久,如果客观条件具备则随时可能爆发冲突. ...