Cubic permutations¶
The cube, 41063625 (3453), can be permuted to produce two other cubes: 56623104 (3843) and 66430125 (4053). In fact, 41063625 is the smallest cube which has exactly three permutations of its digits which are also cube.
Find the smallest cube for which exactly five permutations of its digits are cube.
Even though this problem talks about permutation, we should not think of permuting each and every cube to get our answer. This will consume a lot of resources and the answer will probably take days.
But after scratching my head for many days I was able to arrive at a solution. The algorithm works on the basics of permutations. I will exaplain you the basics first.
Consider two lists -
But after scratching my head for many days I was able to arrive at a solution. The algorithm works on the basics of permutations. I will exaplain you the basics first.
Consider two lists -
[1, 2, 3]
and [3, 2, 1]
. Now lets check the permutations of these two lists.
In [1]:
# importing permutations function
from itertools import permutations
# first list
list_1 = [1, 2, 3]
# second list
list_2 = [3, 2, 1]
# check if both the lists are same
print (list_1 == list_2)
print "First List"
# lets print the permutations of first list
for i in permutations(list_1):
print i
print "Second List"
# lets print the permutations of second list
for j in permutations(list_2):
print j
If you have observed, even though both the lists are different, the permutations of these are same. With the above test, we can conclude that if the contents of the list are same then the permutations are same.
Here goes the algorithm
As we don't know the end we will use
Here goes the algorithm
As we don't know the end we will use
while
loop so that it will go on till infinity.- Lets create a list and name it
cubes
.
- For each and every iteration, we will create a sorted list of string of cube of the number[
sorted(list(string(i3)))
].
- We wil add that
cube
to thecubes
list.
- Count the number of times
cube
is in thecubes
list. If it is 5 times, then break the loop and print the cube of first instance ofcube
in the list.
Program¶
In [ ]:
# http://radiusofcircle.blogspot.com
# import time
import time
# time at the start of program
start = time.time()
# list to store cubes
cubes = []
# iterator
i = 0
# while loop
while True:
# cube of the number
cube = sorted(list(str(i**3)))
# appending the cube to cubes list
cubes.append(cube)
# check if it occured 5 times
if cubes.count(cube) == 5:
# print the cube of the smallest such cube
print (cubes.index(cube))**3
break
i += 1
# time at the end of program
end = time.time()
# total time taken
print end - start
Lets consider an example.
Assume that, python has already done some iterations and the present value of
We will see what
Assume that, python has already done some iterations and the present value of
i = 27
We will see what
sorted(list(str(i**3)))
does:
In [2]:
# i
i = 27
# str(i**3)
print str(i**3)
# list(str(i**3))
print list(str(i**3))
# sorted(list(str(i**3)))
print sorted(list(str(i**3)))
So at any point of time, if there are more than one permutations of 19683(273) are cubes, then
In similar way, we will have sorted list of cubes of numbers(
After we've found the
As the present
You can download the code from Github Gist pep62.py
sorted(list(str(i**3)))
will always return ['1', '3', '6', '8', '9']
.In similar way, we will have sorted list of cubes of numbers(
cubes
list). As list supports duplicates, none of the duplicated values are erased.After we've found the
cube
, we will append the cube to the cubes
list.As the present
cube
also becomes part of cubes
list, we will count
if there are 5 such values of cube
. If yes we will break the loop, otherwise the loop continues.You can download the code from Github Gist pep62.py
Output¶
Summary¶
This problem, once I have got the solution seems to be very simple. But when I tried solving, I banged my head to get the solution. Actually the mistake was on my side. I was thinking only in one way. i.e. to solve it using the permutations function. But at the end it was actually not necessary. Anyways it is a very simple problem once you will understnd that there is no need for the concepts of permutations. I had fun solving this problem.If you have any doubts or didn't understand anything, comment in the comment box below and I will be glad to help you.
Please comment if I have made any typo or if you have any feedback. If you have any new program or better program comment in the comment box below. I will be very happy to see your comment.
Let me know about this format of writing.
You can also contact me.
Thank you. Have a nice day.😃