| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
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 
 
 
 |   
 
 
 
 |