|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
洛谷2020初赛模拟第16题, 这个算复杂度的题不会, 求助, 代码如下- #include<iostream>
- using namespace std;
- #define MAXN 20
- int gu[MAXN][MAXN];
- int luo(int n, int m) {
- if(n <= 1 || m < 2)
- return 1;
- if(gu[n][m] != -1)
- return gu[n][m];
- int ans = 0;
- for(int i = 0; i < m; i += 2)
- ans += luo(n - 1, i);
- gu[n][m] = ans;
- return ans;
- }
- int main() {
- int n, m;
- cin >> n >> m;
- for(int i = 0; i < MAXN; i++)
- for(int j = 0; j < MAXN; j++)
- gu[i][j] = -1;
- cout << luo(n, m);
- return 0;
- }
复制代码
如图,最坏的情况下就是求 ?处的值,而 ?处的值是所有 ??处的值的和,一个 ??处的值又是所有 ???处的值的和,这样一直递归下去,可得第三列的未知值就是第2列中的m/2个元素的和,时间复杂度就是m,而第三列有m个未知值,因此求出第三列所有未知值的时间复杂度就是m2。
此时第三列变成了已知值,问题变成了 已知第三列的值求第四列的值,此时的时间复杂度和 已知第二列的值求第三列的值 的时间复杂度一样,都是m2。自此,我们可以推断出 已知上一列的值求下一列的值 的时间复杂度是m2,而这个过程进行了n-2次,时间复杂度就是m2n
|
|