Skip to main content

Problem 29 Project Euler Solution with python

Distinct powers

Consider all integer combinations of ab for 2 ≤ a ≤ 5 and 2 ≤ b ≤ 5:

22=4, 23=8, 24=16, 25=32
32=9, 33=27, 34=81, 35=243
42=16, 43=64, 44=256, 45=1024
52=25, 53=125, 54=625, 55=3125
If they are then placed in numerical order, with any repeats removed, we get the following sequence of 15 distinct terms:

4, 8, 9, 16, 25, 27, 32, 64, 81, 125, 243, 256, 625, 1024, 3125
How many distinct terms are in the sequence generated by ab for 2 ≤ a ≤ 100 and 2 ≤ b ≤ 100?

This problem doesn't require a lot of background work, just a bit of basics in python can solve this problem. I think you should read the following two articles before seeing the program. They are optional of course.

I think there is no need for any algorithm because we just have used a very direct and basic solution.

Program 

In this program we have used sets at the end even though sets are unordered lists because we are not actually concerned about the order in which the numbers are arranged but we are concerned about the length of the iterable. You can arrange the order if you want to. The solution will be the same even if you will arrange the order or not.
 
You might be wondering with a few questions after seeing the program. 

Why did I use lists instead I could have just used sets?
When I tried sets, instead of lists I found that there was no considerable improvement in the performance, may be because we are just looping for small range. I have sticked myself to lists so that the code is readable and easy to understand for each and everyone.

Why did I use append instead of extend?
When I tried extend instead of append I found that the execution time increased. This might be because of converting each and iterable to a list to add it. I am not sure why, but you can tell it to me if you know why. 

Why did I use '**' instead of using pow()?
Again I have seen same execution time for both of these methods and I have sticked myself to using the more familiar '**' instead of pow().

Guys I am writing what I have seen on my computer. This might not be the case on your computer. I suggest you check these on your computer and you can comment your experience in the comment box below. Please do include the reason in the comment if you know.

Discussions are welcome.

You can download the source code from Github Gist pep29.py

Output


Summary

I am not bothered about the performance of the program because it is running under 1/50 of a second. Also it didn't take a lot of time for me to solve this problem. This may be because of using python for programming the solution, which already has a lot of in-built tools for over coming some of the common problems. 

If you have any doubt or didn't understand anything then feel free to comment in the comment box below and I will be glad to help you as soon as possible.

Please feel free to comment if you have found any typo or have a better solution or a different program or any suggestion. 

You can also contact me.

Thank you. Have a nice day😃.

Popular posts from this blog

Problem 60 Project Euler Solution with python

Prime pair sets The primes 3, 7, 109, and 673, are quite remarkable. By taking any two primes and concatenating them in any order the result will always be prime. For example, taking 7 and 109, both 7109 and 1097 are prime. The sum of these four primes, 792, represents the lowest sum for a set of four primes with this property. Find the lowest sum for a set of five primes for which any two primes concatenate to produce another prime. This problem is j u st a brute force problem. If you have come here because you don't know the limit upto which you will h ave to gener ate the prime numbers t hen go ahe ad and t r y with 10,000 . When I first start ed solving the problem I chose 1 million(beca use most of the problem s on project E uler have this limit ), but it took very long for the computer to fin d the solution. After searching on the internet then I found many people choosing 10, 000 so I have changed my in put f rom 1 million to 10000 and the output was f ast. He

Add/Embed SVG to Blogger website

In this post I will tell you my method(trick) of adding SVG images in a blogger website or blog. Before starting , the first thin g I am assu m ing is that you are aware of SVG if you are here. If not please see S calable V ec tor G raphics Recently when I tried to embed a SVG image for a post on pygal, I tried uploading the SVG file and blogger Image uploader came up with an error, because of which I had to find some other way.  SVG File upload Error in Blogger  I started sea rc hing Google " Embed SVG in Blogger " . I found blogorrhea , w h ich gave some i nformatio n on add ing SVG directly as a markup , which worked , but I faced another problem using this . Also th is guy has used lot of Javascript which was confusin g for me, being new to using SVG.   So I first t houg ht of learning on h ow to embed SVG in HTML and t his on e worked out. Actually we can embed SVG in HTML i n following ways: Using Object tag Using Iframe tag Using embed tag Us

Making a quiz web app with python and flask

Edit : When you are creating a web app with h tml templates, then y ou will have to sa ve the html file in templates folder in the Current Wor ki ng Directory( CWD). If you save the file in the C W D directl y you will get a TemplateNotFound error. Thank you Udhay for pointing it out.   In this post we will create a quiz website using python . I will be using the flask framework . After reading this tutorial you will learn form submission , flask templates , python code in flask templates , shuffling the questions and options with the random module and few others.  Please note that this tutorial is not big as it seems to be. Some of the code has been rewritten to maintain consistency and also font size is somewhat big so that your eyes won't get stressed reading this tutorial. Also the content has not occupied the full width of the page. In this tutorial I am assuming that you are having a very basic understanding of the flask framework . Please refer the documentation