鱼C论坛

 找回密码
 立即注册
查看: 2004|回复: 7

[已解决]递归的时间复杂度

[复制链接]
发表于 2022-8-18 11:08:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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;
} 
最佳答案
2022-8-18 14:05:27
如图,最坏的情况下就是求  ?处的值,而  ?处的值是所有  ??处的值的和,一个  ??处的值又是所有  ???处的值的和,这样一直递归下去,可得第三列的未知值就是第2列中的m/2个元素的和,时间复杂度就是m,而第三列有m个未知值,因此求出第三列所有未知值的时间复杂度就是m2。
此时第三列变成了已知值,问题变成了 已知第三列的值求第四列的值,此时的时间复杂度和 已知第二列的值求第三列的值 的时间复杂度一样,都是m2。自此,我们可以推断出 已知上一列的值求下一列的值 的时间复杂度是m2,而这个过程进行了n-2次,时间复杂度就是m2n
屏幕截图 2022-08-18 110827.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-8-18 12:32:55 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-8-18 13:11:31 | 显示全部楼层


我看答案就看的这个 , 这个跟没解释没区别吧
算了, 反正这种题也只能猜猜了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-18 14:05:27 | 显示全部楼层    本楼为最佳答案   
如图,最坏的情况下就是求  ?处的值,而  ?处的值是所有  ??处的值的和,一个  ??处的值又是所有  ???处的值的和,这样一直递归下去,可得第三列的未知值就是第2列中的m/2个元素的和,时间复杂度就是m,而第三列有m个未知值,因此求出第三列所有未知值的时间复杂度就是m2。
此时第三列变成了已知值,问题变成了 已知第三列的值求第四列的值,此时的时间复杂度和 已知第二列的值求第三列的值 的时间复杂度一样,都是m2。自此,我们可以推断出 已知上一列的值求下一列的值 的时间复杂度是m2,而这个过程进行了n-2次,时间复杂度就是m2n
屏幕截图 2022-08-18 133815.jpg
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-18 14:06:39 | 显示全部楼层
tommyyu 发表于 2022-8-18 14:05
如图,最坏的情况下就是求  ?处的值,而  ?处的值是所有  ??处的值的和,一个  ??处的值又是所有  ? ...

其实只要仔细想就可以想出来了,但是这个基本上网上没有人去想,我搜到的答案都说不会,然后没有讲解
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-8-18 14:20:06 | 显示全部楼层
tommyyu 发表于 2022-8-18 14:05
如图,最坏的情况下就是求  ?处的值,而  ?处的值是所有  ??处的值的和,一个  ??处的值又是所有  ? ...

强啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-18 17:41:09 | 显示全部楼层
CSP-J 还是 CSP-S的模拟?

洛谷的我一般不看
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-8-18 18:09:44 | 显示全部楼层
嘉岳呀 发表于 2022-8-18 17:41
CSP-J 还是 CSP-S的模拟?

洛谷的我一般不看

scpj
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-17 01:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表