社区讨论
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 条回复,欢迎继续交流。
正在加载回复...