A - Function Run Fun POJ - 记忆化搜索-裸

  • A - Function Run Fun

  •  POJ - 1579 
  • #include<iostream>
    #include<stdio.h>
    #include<cstring>
    using namespace std;
    #define inf 0x3f3f3f3f
    int mp[100][100][100];
    int x,y,z;
    int memory(int x,int y,int z)
    {
        if(x<=0||y<=0||z<=0)
            return 1;
        if(mp[x][y][z]!=inf)return mp[x][y][z];
        if(x>20||y>20||z>20)
            return mp[x][y][z]=memory(20,20,20);
        if(x<y&&y<z)
            return mp[x][y][z]=memory(x,y,z-1)+memory(x,y-1,z-1)-memory(x,y-1,z);
        return mp[x][y][z]=memory(x-1,y,z)+memory(x-1,y-1,z)+memory(x-1,y,z-1)-memory(x-1,y-1,z-1);
    }
    int main()
    {
        memset(mp,inf,sizeof(mp));
        while(~scanf("%d%d%d",&x,&y,&z))
        {
            if(x==-1&&y==-1&&z==-1)
                break;
            printf("w(%d, %d, %d) = %d\n",x,y,z,memory(x,y,z));
        }
        return 0;
    }

     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值