求和序列 (n^2-1^2) + 2(n^2-2^2) +….n(n^2-n^2)
Aug 26, 2023 pm 06:53 PM在本文中,我們將研究計算序列和的不同方法- (n^2 - 1^2) 2(n^2 - 2^2) …. n(n ^2 - n^2)。在第一種方法中,我們將逐一計算範圍為1到n的每個i的序列和,並將其添加到最終和中。
在第二種方法中,我們將推導出一個數學公式來計算給定係列的總和,這將使程式的時間複雜度從O(n)降低到O(1)。
問題陳述 − 我們給定一個數字“n”,我們的任務是計算給定序列的和(n^2 - 1^2) 2(n^2 - 2^2) …. n (n^2 - n^2)。
Example
輸入 − 數字 = 5
輸出 - 當n = 5時,級數(n^2 - 1^2) 2(n^2 - 2^2) …. n(n^2 - n^2)的和為150。
輸入 − 數字 = 3
輸出 - 對於n = 3,級數(n^2 - 1^2) 2(n^2 - 2^2) ….n(n^2 - n^2)的和為18。
方法一
這是最簡單的暴力方法來解決序列求和問題。
經過仔細分析這個數列,我們可以得出結論:對於任一個數n,我們有
Sum = ∑ i*(n^2 - i^2) for i = 1 to i = n.
因此,對於暴力破解方法,我們可以在循環中使用上述公式,i從1到n,以產生所需的求和。
Example
這種方法的程式碼如下:
1 2 3 4 5 6 7 8 9 10 11 |
|
輸出
1 |
|
複雜性
時間複雜度 - O(n),因為我們透過循環迭代從1到n的數字。
空間複雜度 - 由於我們沒有使用任何外部空間,因此此方法的空間複雜度為O(1)。
方法二
在這種方法中,我們將推導出一個公式,直接得到所需的序列和,因此不需要迭代,這種方法將以常數時間複雜度解決給定的問題。
如前所述,我們得到了系列的一般版本,給定為
1 |
|
同一系列可以寫成:
1 |
|
我們已經知道計算從1到n的所有數字的和以及計算從1到n的所有數字的立方和的公式,分別為:
從1到n的所有數字的總和
1 |
|
其中 n 是給定的數字。
現在,求從1到n的所有數字的立方和
1 |
|
所以給定的系列可以寫成-
1 |
|
Sum可以進一步簡化為-
1 2 3 4 5 |
|
因此,我們只需要計算Sum = (n^4)/4 - (n^2)/4,對於任何n,以獲得所需的序列的和。
Example
這種方法的程式碼如下:
1 2 3 4 5 6 7 8 9 |
|
輸出
1 |
|
複雜性
時間複雜度 - O(1),因為我們只是使用我們推導出的公式計算所需的總和。
空間複雜度 - 由於我們沒有使用任何外部空間,因此此方法的空間複雜度為O(1)。
結論 - 在本文中,我們討論了計算所需係列總和的兩種方法,並且在第二種方法中,我們將時間複雜度降低到常數。
以上是求和序列 (n^2-1^2) + 2(n^2-2^2) +….n(n^2-n^2)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱門文章

熱門文章

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)