Skip to main content

Problem 28 Project Euler Solution with python

Number spiral diagonals

Starting with the number 1 and moving to the right in a clockwise direction a 5 by 5 spiral is formed as follows:
21 22 23 24 25
20  7  8  9 10
19  6  1  2 11
18  5  4  3 12
17 16 15 14 13
It can be verified that the sum of the numbers on the diagonals is 101.
What is the sum of the numbers on the diagonals in a 1001 by 1001 spiral formed in the same way?

You will have to analyze the question and find the pattern to solve this question. It took me a few hours to solve this problem but I was not able to post the solution these many days because I had some other important work which I had to complete.

My approach to solve this problem was to find the pattern and write a program which can generate the solution. We are not going to do any mathematics deriving any new equations to get the solution.

Please make sure that you will read all of this post so that you will understand the underlying concept perfectly. Remember that these patterns are only applicable for any nxn square matrix where n is odd number.

Consider the following matrices:
3x3 number spiral matrix
5x5 number spiral matrix
You can see that, if we draw lines connecting the outer elements then there are four numbers on the corner of each squares and also these numbers are part of diagonal elements. One more observation is that the numbers are all odd numbers.

Consider the 3x3 matrix in the first picture, we can see that the largest number in the matrix is 9(3x3), see the 5x5 matrix, the largest number in the matrix is 24(5x5) and similarly if you draw a nxn matrix then the largest number in the matrix is n2.

Keeping aside above two matrices see the following 7x7 matrix. I have highlighted all the diagonal elements.
7x7 number spiral matrix
I have chosen a larger matrix because I wanted to show you the pattern I found, which is very hard to show in case of a smaller matrix.

As of now according to our analysis we know that only odd numbers get the chance to be diagonal elements in the number spiral, for each and every square formed we have only four diagonal elements. So in the above matrix(7x7 matrix) we have 3 squares and 12 diagonal elements excluding 1.

Writing the odd numbers for 7x7 matrix:

1,3,5,7,9,11,13,15,17,19,21,23,25,27,29,31,33,35,37,39,41,43,45,47,49.

Highlighting the numbers which are diagonals in different squares in 7x7 matrix:
1,3,5,7,9,11,13,15,17,19,21,23,25,27,29,31,33,35,37,39,41,43,45,47,49.

Now if you have observed first square the values doesn't have a gap between the numbers. For the second square the numbers have a gap of 1 number between each. For the third square the numbers have a gap of 2 numbers between each. This continues upto infinity.

So if we can understand the pattern then we can write the diagonal elements for any size of number spiral matrix. Now for 9x9 matrix the diagonal elements will be(writing the values without actually creating the diagram):
1,3,5,7,9,11,13,15,17,19,21,23,,25,27,29,31,33,35,37,39,41,43,45,47,49,51, 53,55,57,59,61,63 ,65,67,69,71,73,75,77,79,81.

I think you have understood the pattern. To be simple the gap between the odd numbers increases for every four iterations. Four numbers because we can only have four corners for a square.

Now see the program and you will understand everything easily.

Program

According to the question, we know that the last number for our iteration will be 1002001. Also the number will be the fourth iteration in the outer square of the 1001x1001 matrix. So we can stop looping when we hit the number 1002001. The same thing has been accomplished in the program.

In solution we have added 1 already because it is an exception for our pattern😋.

You can download the source code form Github Gist pep28.py

Output

Summary

It took me some time to find the pattern in the question given, but I am really satisfied with the performance of the program. Few others have solved the problem by creating a formula but as I wanted to solve the problem writing a program I have not created any formula. Hope you have liked the solution.

If you haven't understood anything or have any doubt feel free to comment and I will reply to you as soon as possible. 

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

You can also contact me.

Thank you. Have a nice day😃.

Popular posts from this blog

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

Problem 11 Project Euler Solution with python

Largest product in a grid In the 20×20 grid below, four numbers along a diagonal line have been marked in red. 08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08 49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00 81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65 52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91 22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80 24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50 32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70 67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21 24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72 21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95 78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92 16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57 86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58 19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40 04 52 08 83 97 35 99 16 07

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