Skip to main content

Problem 41 project Euler Solution with python

Pandigital prime

We shall say that an n-digit number is pandigital if it makes use of all the digits 1 to n exactly once. For example, 2143 is a 4-digit pandigital and is also prime.
What is the largest n-digit pandigital prime that exists?


An another question on Pandigital. I have written two solutions, one solution demanded homework and the other required programming logic. Both had their own pros and cons. But I will finalize the solution which demanded the programming skills.

Anyways you can see both the programs below.

Better performing code considers the divisibility of 3. See the Answer written by engineer on Stack Overflow, you will understand the algorithm.
(Second Program I wrote)
# http://radiusofcircle.blogspot.com

# importing the permutations method
from itertools import permutations

# importing time module
import time

# time at the start of program execution
start = time.time()


def is_prime(n):
    """Function to check if
    the given number is prime"""
    for i in xrange(2, int(n**0.5)+1):
        if n % i == 0:
            return False
    return True

# permutations of numbers from 1-7
p = permutations('1234567')

# for loop to loop from reverse order
# from higher to lower
for i in list(p)[::-1]:
    if int(i[6]) % 2 != 0:
        number = int(''.join(i))
        if (number+1) % 6 == 0 or (number-1) % 6 == 0:
            if is_prime(number):
                print number
                break

# time at the end of program execution
end = time.time()

# total time of execution
print end-start
This program gets executed in 0.00150895118713 seconds. But this demanded mathematics rather than more programming logic.

I have explained most of the code in the program section.

Program

Check out itertools.permutations to understand what permutations are.

is_prime
This is a very simple function to check if the given number is prime or not.

Now the value of a = '123456789', which when permuted will give all the 1-9 pandigital numbers. If you don't want 1-9 pandigital and suppose say, you want only 1-7 pandigital number, then consider only a[:7].

flag = True

j = 0, this one is while loop iterator

While loop is executed because the value of flag is True at the instant.

p = permutations(a[:9]) = permutations('123456789')

As we know that the permutations will return all the numbers arranged from small to big. As we wanted bigger prime number we will check from last to first. I have used [::-1] to reverse the given list.

Take an element from the permutations and then check if the last element is not even.

Next condition uses the fact that all the prime numbers are of the form 6k+1 and 6k-1 but the vice versa is not true.

If the number passes the above test then check if it is prime. If it is prime then this will be the largest pandigital prime number because we are coming in reverse order.

If any prime is not found in the present iteration then start checking permutations of '12345678', i.e.j = 8 = 9-1. At the end when the prime is found, print the prime number and then flag = False to stop the outer while loop and break to stop the present for loop.

Output

Summary

This problem took some time for me to complete, but I am really satisfied. I am very happy with the first program I have written because I have used a lot of logic rather than mathematics. Even though the program also had some mathematics it contained more programming logic. Second solution, a child of the first program used a very simple mathematical logic and had a better execution time. I am not happy for not getting this idea until I have seen an answer on Stack.

As always if you have any doubt then you can comment in the comment box below.

Please do comment if you have found any typo or have a different program or have a better program or if you have a suggestion. I will be very happy to view each of them.

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