首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >递归关系: T(n) = T(n - 1) +n-1

递归关系: T(n) = T(n - 1) +n-1
EN

Stack Overflow用户
提问于 2012-06-02 11:23:49
回答 2查看 1K关注 0票数 1

我正在尝试理解如何解决递归关系。我理解这一点,我们必须简化。

代码语言:javascript
复制
T(N) = T(N-1) + N-1              Initial condition: T(1)=O(1)=1
T(N) = T(N-1) + N-1
T(N-1) = T(N-2) + N-2
T(N-2) = T(N-3) + N-3
……
T(2) = T(1) + 1


**Summing up right and left sides**

T(N) + T(N-1) + T(N-2) + T(N-3) + …. T(3) + T(2) =

= T(N-1) + T(N-2) + T(N-3) + …. T(3) + T(2) + T(1) +

(N-1) + (N-2) + (N-3) + …. +3 + 2 + 1


** Canceling like terms and simplifying **

T(N) = T(1) + N*(N-1)/2 1 + N*(N - 1)/2

T(N) = 1 + N*(N - 1)/2

我真的不明白最后一部分。我理解取消like术语,但不理解下面的简化是如何工作的:

代码语言:javascript
复制
T(N) = T(1) + (N-1) + (N-2) + (N-3) + …. +3 + 2 + 1
T(N) = T(1) + N*(N-1)/2 1 + N*(N - 1)/2

第二行是如何从第一行派生出来的?对我来说没有任何意义。

如果有人能帮我理解这一点,那就太好了。谢谢=)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-06-02 11:41:21

在你的倒数第二行中:

代码语言:javascript
复制
 S = (N-1) + (N-2) + (N-3) + ... + 3 + 2 + 1

你可以说:

代码语言:javascript
复制
2S = S + S
   = (N-1) + (N-2) + (N-3) + ... +   3   +   2   +   1
       1   +   2   +   3   + ... + (N-3) + (N-2) + (N-1)
   =   N   +   N   +   N   + ... +   N   +   N   +   N
       |__________________ N-1 times ________________|

您将从N - 1计数到1,因此序列中有N - 1项。但是整个序列都是N,所以你可以这样说:

代码语言:javascript
复制
2S = N * (N - 1)
 S = (N * (N - 1)) / 2

所以在你的最后一块中:

代码语言:javascript
复制
T(N) = T(1) + (N-1) + (N-2) + (N-3) + ... + 3 + 2 + 1
     = T(1) + (N * (N - 1)) / 2
票数 1
EN

Stack Overflow用户

发布于 2012-06-02 11:50:56

代码语言:javascript
复制
T(N) = T(1) + (N-1) + (N-2) + (N-3) + …. +3 + 2 + 1
     = T(1) + (N-1) +  (N-2) + (N-3) + ..... + ( N-(N-3)) + (N-(N-2)) + (N-(N-1))
     = T(1) + [N+N+N+..... n-1 times] - [1+2+3+......+(N-3)+(N-2)+(N-1)]
     = T(1) + N*(N-1) - (N*(N-1))/2
     = T(1) + N*(N-1)/2
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10859553

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档