記憶化搜索

傳送門添加鏈接描述

#include <bits/stdc++.h>
using namespace std;
int r[22][22][22];
int w(int a,int b,int c)
{
    if(a<=0||b<=0||c<=0) return 1;
    if(a>20||b>20||c>20) return w(20,20,20);
    if(r[a][b][c]) return r[a][b][c];//避免重複計算
    if(a<b&&b<c) r[a][b][c]=w(a,b,c-1)+w(a,b-1,c-1)-w(a,b-1,c);
    else r[a][b][c]=w(a-1,b,c)+w(a-1,b-1,c)+w(a-1,b,c-1)-w(a-1,b-1,c-1);
    return r[a][b][c];
}
int main()
{
    int a,b,c;
    while(cin >> a >> b >> c)
    {
        if(a==-1&&b==-1&&c==-1) break;
        printf("w(%d, %d, %d) = ",a,b,c);
        printf("%d\n",w(a,b,c));
    }
    return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章