Skip to main content

Projecteuler.net: Problem 4: Matlab: Largest Palindrome Product

Problem4 projecteuler.net

A palindromic number reads the same both ways. The largest palindrome made from the product of two 2-digit numbers is 9009 = 91 × 99.
Find the largest palindrome made from the product of two 3-digit numbers. Solve using Matlab?


Solution

Here to find the solution we will generate number which are product of three digit number and will check if the number is palindrome or not. Finally we will find the largest number of the given set and that will be the solution.

If you don't know the ispalindrome function then go to our previous post on what is palindrome and the palindrome function to get a good idea to solve this problem. Click here to go to the post: 
Download the ispalindrome.m matlab file from here: ispalindrome.m
Note that the explanation for the program is below the program section, this program will take a minute or two to generate the answer, because we will have to loop through so many numbers.

Program

%This script will generate largest palindrome number which 
%is a multiple of three digit numbers

%An empty vector to store all the palindrome numbers
vec = [];


%Two for loops are created to loop through the multiplication
for i = 100:999
    for j = 100:999
        number = i*j;
        if ispalindrome(number)
            vec = [vec number];
        end
    end
end

vec = max(vec)

Explanation

In this script an empty vector is created to store the numbers generated which are palindrome.
Now two for loops are created to generate the value of multiples.
To make it simple we will go through the first two iterations and you will get a clear cut understanding.

First iteration

During the first iteration i = 100 now the computer will dig through the next line and again it will find another loop. In this iteration with the second loop the numbers generated are as follows:

i = 100, j = 100
i = 100, j= 101
i = 100, j = 102
.
.
.
i = 100, j = 999

Second iteration

During the second iteration the i value changes to 101 and the same process continues. The iterator values are as follows:

i = 101, j = 100
i = 101, j = 101
i = 101, j = 102
.
.
.
i = 101, j = 999

This iterations will continue till the i value 999 is reached.

In the next line there is a number variable which will find the product of i and j. So for every iteration of i 999 numbers are generated, and for every iteration of j 1 number is produced.

The ispalindrome function will check whether the number is palindrome or not and will store the number in the vec vector if the number is palindrome. 

Finally we will have a vector with all the palindrome numbers which are multiples of  two three digit numbers. We will use the max function in matlab to get the maximum valued number in the vector generated.

To download the this post and read online click here: problem4_projecteuler_matlab.pdf

The above code is formatted using hilite.me

This problem is from projecteuler.net and can be found here: problem4

Run the program and comment below the output you are getting for a given input.

Keywords: projecteuler.net, problem 4, for loop, Largest Palindrome Product, Palindrome Numbers

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