zoukankan      html  css  js  c++  java
  • 洛谷P2822 组合数问题

    输入输出样例

    输入样例#1: 
    1 2
    3 3
    输出样例#1: 
    1
    输入样例#2: 
    2 5
    4 5
    6 7
    输出样例#2: 
    0
    7
    

    说明

    【样例1说明】

    在所有可能的情况中,只有C_2^1 = 2C21=2是2的倍数。

    【子任务】


    题目非常的长,但是意思很简单,就是求杨辉三角i行j列中能被k整除的数

    因为组合数的意义其实就是杨辉三角(不懂得可以百度一下)好吧我接下来说一说

    如图应该很明显了,但是对于OI来说的话可能放到左边用数组表示更加直观,顺便一提,最上方也可以加一个1,如图

     

     求第i行第j列中被k整除的数的个数如下

    我们可以先将杨辉三角打印出来,当然这里可以优化一下,将杨辉三角中能被k整除的数直接标为0

    for(int i=0;i<=2000;i++) c[i][0]=1;
        for(int i=1;i<=2000;i++) 
            for(int j=1;j<=2000;j++)
            {
                c[i][j]=(c[i-1][j]+c[i-1][j-1])%k;
            }

    我们设f[i][j]为第i行第j列之前的数中能被f整除的数,则f[i][j]=f[i-1][j]+f[i][j-1]-f[i-1][j-1]+(c[i][j]==0)(注意这里(c[i][j]==0)是个判断,为了好写就加上了

    那么我们注意到当i==j时,f[i][j-1]是空的,也就是少一个f[i][i]的值,所以要在j=i时加上一个f[i][i]

    核心代码如下:

     for(int i=1;i<=2000;i++)
        {
            for(int j=1;j<=i;j++)
            {
                f[i][j]=f[i-1][j]+f[i][j-1]-f[i-1][j-1];
                if(c[i][j]==0)f[i][j]++;
            }
            f[i][i+1]=f[i][i];//这里要到下一个i才会用到,所以在最后加
        }

    那么完整版的ak代码经过修改组合就出来了:

    #include<iostream>
    #include<cstdio>
    #include<cstdlib>
    #include<cstring>
    #include<string>
    #include<cmath>
    #include<algorithm>
    #include<iomanip>
    using namespace std;
    int n,m,t,k,c[2001][2001],f[2001][2001];
    int main()
    {
        cin>>t>>k;
        for(int i=0;i<=2000;i++) c[i][0]=1;
        for(int i=1;i<=2000;i++) 
            for(int j=1;j<=2000;j++)
            {
                c[i][j]=(c[i-1][j]+c[i-1][j-1])%k;
            }
        for(int i=1;i<=2000;i++)
        {
            for(int j=1;j<=i;j++)
            {
                f[i][j]=f[i-1][j]+f[i][j-1]-f[i-1][j-1];
                if(c[i][j]==0)f[i][j]++;
            }
            f[i][i+1]=f[i][i];
        }
        for(int i=1;i<=t;i++)
        {
            cin>>n>>m;
            if(m>n)m=n;
            cout<<f[n][m]<<endl;;
        }
        return 0;
    }

    特别鸣谢:hmr大佬,感谢大佬亲身讲解

    大佬博客  https://www.cnblogs.com/hanruyun/

  • 相关阅读:
    bzoj1593[Usaco2008 Feb]Hotel旅馆
    spoj1182 Sorted bit squence/[USACO2003 Dec]Cow Queueing
    [USACO2003 Dec]Cow Queueing数数的梦 (基础水数位DP带注释!)
    后缀数组模版+注释
    bzoj1690/poj3621[Usaco2007 Dec]奶牛的旅行
    bzoj1731/poj3169[Usaco2005 dec]Layout 排队布局
    bzoj2467[中山市选2010]生成树
    bzoj1594[Usaco2008 Jan]Haybale Guessing猜数游戏
    poj 1035 -- Spell checker
    poj 1611 -- The Suspects
  • 原文地址:https://www.cnblogs.com/lcezych/p/10598718.html
Copyright © 2011-2022 走看看