社区讨论

100,Unaccepted

P1464Function参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@ly79gtyf
此快照首次捕获于
2024/07/04 20:46
2 年前
此快照最后确认于
2024/07/05 00:17
2 年前
查看原帖
CPP
#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<stack>
#include<queue>
#include<vector>
#include<deque>
#include<set>
#include<map>
using namespace std;
typedef int64_t ll;
const int N=1e5+10;
ll A[25][25][25],B[25][25][25];
bool visa[25][25][25],visb[25][25][25];

ll w(ll a,ll b,ll c)
{
    if(a<=0||b<=0||c<=0) return 1;
    if(a>20||b>20||c>20) return w(20,20,20);
    if(a<b&&b<c)
    {
        if(visa[a][b][c]) return A[a][b][c];
        A[a][b][c]=w(a,b,c-1)+w(a,b-1,c-1)-w(a,b-1,c);
        visa[a][b][c]=1;
        return A[a][b][c];
    }
    if(visb[a][b][c]) return B[a][b][c];
    B[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);
    visb[a][b][c]=1;
    return B[a][b][c];
}

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    ll a,b,c;
    for(int i=1;1;++i)
    {
        cin>>a>>b>>c;
        if(a==-1&&b==-1&&c==-1) break;
        memset(visa,0,sizeof(visa));
        memset(visb,0,sizeof(visb));
        cout<<"w("<<a<<", "<<b<<", "<<c<<") = "<<w(a,b,c)<<endl;
    }

    return 0;
}

回复

2 条回复,欢迎继续交流。

正在加载回复...