Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
112270 | 林泽豪 | 整数拆分 | C++ | 解答错误 | 66 | 0 MS | 268 KB | 292 | 2023-11-25 11:21:38 |
#include<bits/stdc++.h> using namespace std; int dp[1000]={1,1,2,3}; int sb(int an) { int a=0; if(dp[an]==0){ for(int i=an/2;i>=1;i--){ a=max(i*sb(an-i),a); } dp[an]=a; }else { a=dp[an]; } return a; } int main() { int n; cin>>n; cout<<sb(n); }