3 回答
data:image/s3,"s3://crabby-images/0df7d/0df7db29abb36e68052e541fd078daa4a11749a6" alt="?"
TA贡献2037条经验 获得超6个赞
最坏情况下的时间复杂度计算如下(假设字符串最大长度为 n):
newStr = '' # will be done once so 1 time.
for chr in string: # is iterating on the input with max length of n so n times.
if chr.isspace(): # will be checked once it is in the loop so 1 time per each iteration.
newStr = newStr + ' ' # also once per iteration if the if condition is satisfied
else: # will be chehcked once per iteration
newStr += str(ord(chr)) # if else is satisfied
return newStr # will be done 1 time.
我们将假设常数时间是 c 所以:
Time complexity = 1 + n(c*c + c*c) + 1 = 2+Cn => O(n)
data:image/s3,"s3://crabby-images/35527/35527520361f68aaa9d71809e7e566f0ecb701c6" alt="?"
TA贡献1798条经验 获得超3个赞
这个解仍然是 O(n)。实际上,我不完全确定为什么 else 语句会影响这一点。您正在对字符串中的每个字符执行一次操作。
即使对于每个字符,您正在执行多个指令(比较等),您可能认为复杂性类似于 O(3n),但您当然忽略了系数。我相信您知道这一点,但是对于将来查看此问题、对 else 语句感到困惑的人来说,这可能会有所帮助。
添加回答
举报