`
kmplayer
  • 浏览: 496410 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

国际大学生程序设计竞赛例题_5.7三只小猪

J# 
阅读更多
1,题意:m个房子,n只小猪,(n>=m),房间保证住满,问共有多少种方案?
2,解答:动态规划
d[i][j]:j只小猪住i个房子的方案.
初始化:d[i][j]=0,d[1][j>=1]=1;
状态转移:
d[i][j]=1;(i==j)
d[i][j]=d[i-1][j-1]+d[i][j-1]*i;(i<j)
3,实例代码:
#include <iostream>
using namespace std;

const int maxL=250;

struct big_num
{
    int a[maxL];
public:
    void init()
    {
        memset(a,0,sizeof(a));
    }
    big_num operator=(int obj)
    {
        init();
        int n=0;
        while(obj)
        {
            a[n++]=obj%10000;//1位放四位数
            obj/=10000;
        }
        return *this;
    }
    big_num operator*(int obj)
    {
        big_num other;
        other.init();
        int add=0;//进位
        int n;//最高位的下标
        for(n=maxL-1;n>=0&&!a[n];n--);
        int i;
        for(i=0;i<=n;i++)
        {
            other.a[i]=(a[i]*obj+add)%10000;
            add=(a[i]*obj+add)/10000;
        }
        other.a[i]=add;
        return other;
    }

    big_num operator+(big_num obj)
    {
        big_num other;
        other.init();
        int add=0;//进位
        for(int i=0;i<maxL;i++)
        {
            other.a[i]=(a[i]+obj.a[i]+add)%10000;
            add=(a[i]+obj.a[i]+add)/10000;
        }
        return other;
    }

    void output()
    {
        int n;//最高位的下标
        for(n=maxL-1;n>=0&&!a[n];n--);
        if(n<0)
        {
            cout<<"0"<<endl;
            return;
        }
        for(int i=n;i>=0;i--)
        {
            if(i==n) cout<<a[i];
            //可能全0,所以需要一位一位处理
            else
            {
                int temp=a[i];
                int k=1000;
                while(k)
                {
                    cout<<temp/k;
                    temp%=k;
                    k/=10;
                }
            }
        }
        cout<<endl;

    }
};

const int maxN=100;

big_num d[maxN][maxN]; //状态数组
void initState()
{
    for(int i=0;i<maxN;i++)
        for(int j=0;j<maxN;j++)
            d[i][j]=0;
    for(int i=1,j=1;j<maxN;j++)
        d[i][j]=1;
}

int cnt;

int main()
{
    freopen("5.7.in","r",stdin);
    cin>>cnt;
    int n,m;//小猪数和房子数
    while(cnt--)
    {
        cin>>n>>m;
        initState();
        for(int i=1;i<=m;i++)
            for(int j=i;j<=n;j++)
            {
                if(i==j) d[i][j]=1;
                else
                    d[i][j]=d[i-1][j-1]+d[i][j-1]*i;
            }
        d[m][n].output();
    }
    return 0;
}
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics