【题目描述】

【输入格式】

从文件中读入数据。

第一行有两个整数t, k,其中t代表该测试点总共有多少组测试数据,k的意义见【问题描述】。

接下来t行每行两个整数n, m,其中n, m的意义见【问题描述】。

【输出格式】

输出到文件中。

t行,每行一个整数代表所有的0<=i<=n,0<=j<=min(i,m)中有多少对(i, j)满足C(j,i)是k的倍数。

【样例1输入】

1 2
3 3

【样例1输出】

1

【提示】

在所有可能的情况中,只有C(1,2)是2的倍数。

【样例2输入】

2 5
4 5
6 7

【样例2输出】

0
7

【来源】

NOIP2016 官方数据、

这道题几天之前在我眼里还是懵逼的

不过今天我们学习了一个公式

C下n+1上m=C下n上m-1+C下n上m、

本来只想推推看看,后来一推就是55

然后加了个%k是90

后来实在做不出来了看了看大神的题解原来可以用前缀和

如此看来noip2016的题也不是很难啊,

     #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
const int MAXN=;
int T,k,n,m;
int dp[MAXN][MAXN];
int read(int & n)
{
int flag=,x=;char c='/';
while(c<''||c>''){c=getchar();if(c=='-')flag=;}
while(c>=''&&c<='')x=x*+(c-),c=getchar();
if(flag)n=-x;else n=x;
}
int main()
{
freopen("problem.in","r",stdin);
freopen("problem.out","w",stdout);
read(T);read(k);
for(int i=;i<=;i++)
dp[i][]=,dp[i][i]=;
for(int i=;i<=;i++)
for(int j=;j<=;j++)
if(dp[i+][j]==)
dp[i+][j]=(dp[i][j]+dp[i][j-]); while(T--)
{
read(n);read(m);
int ans=;
for(int i=;i<=n;i++)
for(int j=;j<=min(i,m);j++)
if(dp[i][j]%k==)
ans++;
printf("%d\n",ans);
}
return ;
}

55

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#define LL long long
using namespace std;
const int MAXN=;
int T,k,n,m;
LL dp[MAXN][MAXN];
LL sum[MAXN][MAXN];
int read(int & n)
{
int flag=,x=;char c='/';
while(c<''||c>''){c=getchar();if(c=='-')flag=;}
while(c>=''&&c<='')x=x*+(c-),c=getchar();
if(flag)n=-x;else n=x;
}
int main()
{
freopen("problem.in","r",stdin);
freopen("problem.out","w",stdout); read(T);read(k);
for(int i=;i<=;i++)
dp[i][i]=,dp[i][]=i%k;
for(int i=;i<=;i++)
for(int j=;j<i;j++)
dp[i][j]=(dp[i-][j]%k+dp[i-][j-]%k)%k; /*for(int l=0;l<=50;l++)
for(int j=0;j<=l;j++)
cout<<dp[l][j];
cout<<endl;*/
//cout<<dp[1][2]; for(int i=;i<=;i++)
for(int j=;j<=i;j++)
{
if(dp[i][j]==)sum[i][j]=sum[i][j-]+;// 满足条件
else sum[i][j]=sum[i][j-];
} while(T--)
{
read(n);read(m);
LL ans=;
for(int i=;i<=n;i++)
ans+=sum[i][min(i,m)];
cout<<ans<<endl;
//printf("%d\n",sum[n][min(n,m)]);
}
return ;
}

AC

2559. [NOIP2016]组合数问题的更多相关文章

  1. Noip2016组合数(数论)

    题目描述 组合数表示的是从n个物品中选出m个物品的方案数.举个例子,从(1,2,3) 三个物品中选择两个物品可以有(1,2),(1,3),(2,3)这三种选择方法.根据组合数的定 义,我们可以给出计算 ...

  2. noip2016组合数问题

    题目描述 组合数 Cnm​ 表示的是从 n 个物品中选出 m 个物品的方案数.举个例子,从 (1,2,3) 三个物品中选择两个物品可以有(1,2),(1,3),(2,3) 这三种选择方法.根据组合数的 ...

  3. NOIP2016 组合数问题

    https://www.luogu.org/problem/show?pid=2822 题目描述 组合数表示的是从n个物品中选出m个物品的方案数.举个例子,从(1,2,3) 三个物品中选择两个物品可以 ...

  4. [Noip2016]组合数(数论)

    题目描述 组合数表示的是从n个物品中选出m个物品的方案数.举个例子,从(1,2,3) 三个物品中选择两个物品可以有(1,2),(1,3),(2,3)这三种选择方法.根据组合数的定 义,我们可以给出计算 ...

  5. Luogu 2822[NOIP2016] 组合数问题 - 数论

    题解 乱搞就能过了. 首先我们考虑如何快速判断C(i, j ) | k 是否成立. 由于$k$非常小, 所以可以对$k$分解质因数, 接着预处理出前N个数的阶乘的因数中 $p_i$ 的个数, 然后就可 ...

  6. [noip2016]组合数问题<dp+杨辉三角>

    题目链接:https://vijos.org/p/2006 当时在考场上只想到了暴力的做法,现在自己看了以后还是没思路,最后看大佬说的杨辉三角才懂这题... 我自己总结了一下,我不能反应出杨辉三角的递 ...

  7. NOIP 2016 组合数问题

    洛谷 P2822 组合数问题 洛谷传送门 JDOJ 3139: [NOIP2016]组合数问题 D2 T1 JDOJ传送门 Description 组合数Cnm表示的是从n个物品中选出m个物品的方案数 ...

  8. noip 2016提高组D2T1 problem

    我们可以先预处理一下组合数模K的值,然后我们可以发现对于答案ji[n][m],可以发现递推式ji[i][j]=ji[i-1][j]+ji[i][j-1]-ji[i-1][j-1]并对于Cij是否%k等 ...

  9. OI 刷题记录——每周更新

    每周日更新 2016.05.29 UVa中国麻将(Chinese Mahjong,Uva 11210) UVa新汉诺塔问题(A Different Task,Uva 10795) NOIP2012同余 ...

随机推荐

  1. 所有的异常都要使用try catch 语句捕获?

    在开发应用程序过程中必须检测代码可能发生的错误并进行正确的处理,这个在理想的情况下,应用程序中的每行 代码都按照预想的执行,要用到的每种资源总是可以利用,但是在实际的开发过程中,写代码难免会出错,或是 ...

  2. JSP的隐藏对象

    以下内容引用自http://wiki.jikexueyuan.com/project/jsp/implicit-objects.html: JSP隐式对象是Java对象,JSP容器使隐式对象在每一个页 ...

  3. COLLECTL LINUX 监控

    http://blog.csdn.net/leichelle/article/details/23590289

  4. C#的SplitPanel如何设置上下和左右

    定位到Orientation属性即可

  5. Js、Jquery对goTop功能的实现

    本文介绍用原生JS和Jquery分别实现的网页goTopbutton功能,以及在这个过程中碰到的问题. 终于实现的效果类似:http://sc2.163.com/home(注意右下角的top) 代码: ...

  6. CI知识:GitLab

    Gitlab简介 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务. 可通过Web界面进行访问公开的或者私人项目.它拥有与Github类似的 ...

  7. 『NSOperation、NSOperationQueue』详解

    1. NSOperation.NSOperationQueue 简介 NSOperation.NSOperationQueue 是苹果提供给我们的一套多线程解决方案.实际上 NSOperation.N ...

  8. dotNet Core初学之创建第一个dotNetCore项目

    首先创建解决方案dotNetCrazy 一.创建项目 1.这里选择.Net Core 选择ASP.NET Core Web 应用程序 名称暂且叫CoreCrazy 这里我们选择 web应用程序(模型视 ...

  9. WWDC笔记:2013 Session 201 Building User Interfaces for iOS 7

    Text Dynamic Type Specifies fonts semantically Supports user text sizing Optimized for legibility Su ...

  10. CI框架下的get_instance() 函数

    你随便下个CI框架的源码都会看到很多的get_instance() 函数,这个函数是用来获取CI 的全局超级对象,CI 是单例模式的框架,所有全局有一个超级对象.因为只有一个实例,所以无论这个函数使用 ...