Sum of Squares of First N Natural Numbers
Sum of Squares of First N Natural Numbers
To find the sum of squares of first N natural numbers, read the value of N from user using input(), then iterate from 1 to N using a For Loop, find square of each number and accumulate it in sum over the iterations.
The sum of squares of first N natural numbers is
sum = 12 + 22 + 32 + . . . + n2
If you are good in remembering formula or remembering that there is a formula, then the following will help you in finding the sum of squares of first n
natural numbers.
n (n + 1) (2n + 1) / 6
We shall go through two of these methods to find the sum of squares of first n natural numbers using Python.
Program using For Loop
In the following program, we shall define a function sumOfSquares()
that takes n
as argument, use For Loop to compute the sum of squares, and then return the sum.
We read n
from user, call sumOfSquares()
with the n
passed as argument.
Input
n
, where n > 0
Python Program
def sumOfSquares(n) :
if n < 0:
return
sum = 0
for i in range(n+1):
sum += i*i
return sum
n = int(input('Enter n : '))
sum = sumOfSquares(n)
print(f'Sum : {sum}')
Output
Enter n : 6
Sum : 91
Important Points regarding above program
- input() function reads a string from standard input. Therefore, we have used int() function to convert string to integer.
- If given
n
is less than zero, we are returning nothing. - We used range(1, n+1) to iterate from 1 to n.
+=
is Addition Assignment Operator.
Program using Formula
In the following program, we shall define a function sumOfSquares()
that takes n
as argument, uses the following formula to compute the sum of squares, and then return the sum.
n (n + 1) (2n + 1) / 6
We read n
from user, call sumOfSquares()
with the n
passed as argument.
Input
n
, where n > 0
Python Program
def sumOfSquares(n) :
if n < 0:
return
sum = n * (n + 1) * (2 * n + 1) / 6
return int(sum)
n = int(input('Enter n : '))
sum = sumOfSquares(n)
print(f'Sum : {sum}')
Output
Enter n : 6
Sum : 91
Since we have division operation in the formula, Python implicitly typecasts the value to floating-point number. We may convert the float to int using int() function.