首页 > 其他 > 详细

bzoj2729: [HNOI2012]排队

时间:2016-07-04 06:27:13      阅读:214      评论:0      收藏:0      [点我收藏+]

高精度+排列组合。

如果计算老师能挨在一起的情况 有 (n+2)! * A(n+3,m)

老师一定挨宰一起的情况 有 2*(n+1)!*A(n+2,m)。

相减就是答案。

#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn = 3000;
const int mod = 10000;

struct bigint { 
    int a[maxn+10];
    
    int& operator[] (int x) {
        return a[x];    
    }
    
    bigint operator * (int x) {
        bigint c;
        for(int i=1;i<=maxn;i++) {
            c[i]+=a[i]*x;
            c[i+1]+=c[i]/mod;
            c[i]=c[i]%mod;
        }
        return c;
    }
    
    bigint operator - (bigint b) {
        bigint c;
        for(int i=1;i<=maxn;i++) {
            c[i]+=a[i]-b[i];
            if(c[i]<0) {c[i]+=mod; c[i+1]--;}
        }
        return c;
    }
    
    void print() {
        int k;
        for(k=maxn;k>=1;k--) if(a[k]) break;
        printf("%d",a[k]);
        for(int i=k-1;i>=1;i--) printf("%04d",a[i]);    
        printf("\n");
    }
    
    bigint() {
        memset(a,0,sizeof(a));    
    }
}t1,t2;

int n,m;

int main() {
    scanf("%d%d",&n,&m);    
    t1[1]=1; t2[1]=2;
    for(int i=1;i<=n+2;i++) t1=t1*i;
    for(int i=n+4-m;i<=n+3;i++) t1=t1*i;
    for(int i=1;i<=n+1;i++) t2=t2*i;
    for(int i=n+3-m;i<=n+2;i++) t2=t2*i;
    t1=t1-t2;
    t1.print();
    return 0;
}

bzoj2729: [HNOI2012]排队

原文:http://www.cnblogs.com/invoid/p/5639275.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!