鱼C论坛

 找回密码
 立即注册
查看: 1089|回复: 3

[已解决]问时间复杂度

[复制链接]
发表于 2023-9-21 16:50:54 From FishC Mobile | 显示全部楼层 |阅读模式

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

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

x
请问这段代码的时间复杂度是多少
int lengthOfLongestSubstring(char * s){
    int hash[128] = {0};    // 模拟哈希表
    int max = 0;    // 最大值
    for(int i = 0, j = 0; i < strlen(s); i++){
        hash[s[i]]++;
        while(hash[s[i]] > 1) hash[s[j++]]--;
        max = max < (i-j+1)?(i-j+1):max;
    }
    return max;
}
最佳答案
2023-9-21 16:51:00
这段代码的时间复杂度是 O(n),其中 n 是字符串 s 的长度。具体分析如下:

1. 初始化哈希表的时间复杂度是 O(1),因为哈希表的大小固定为 128。

2. for 循环的时间复杂度是 O(n),因为它会遍历整个字符串 s。

3. while 循环的时间复杂度也是 O(n),因为它最多会执行 n 次(即 j 最多增加到 i),并且每次执行时会对哈希表进行更新操作。

4. max 的更新操作的时间复杂度是 O(1)。

因此,总的时间复杂度是 O(n)。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-9-21 16:51:00 | 显示全部楼层    本楼为最佳答案   
这段代码的时间复杂度是 O(n),其中 n 是字符串 s 的长度。具体分析如下:

1. 初始化哈希表的时间复杂度是 O(1),因为哈希表的大小固定为 128。

2. for 循环的时间复杂度是 O(n),因为它会遍历整个字符串 s。

3. while 循环的时间复杂度也是 O(n),因为它最多会执行 n 次(即 j 最多增加到 i),并且每次执行时会对哈希表进行更新操作。

4. max 的更新操作的时间复杂度是 O(1)。

因此,总的时间复杂度是 O(n)。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-9-21 17:00:57 From FishC Mobile | 显示全部楼层
isdkz 发表于 2023-9-21 16:51
这段代码的时间复杂度是 O(n),其中 n 是字符串 s 的长度。具体分析如下:

1. 初始化哈希表的时间复杂度 ...

while嵌套在for里面,那时间复杂度不应该是n平方吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-9-21 17:52:20 | 显示全部楼层
O(n2)。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-10-6 04:11

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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