Skip to main content

Check the given number is amstrong number using Matlab

Problem

Write a program in matlab to check whether the given number is Amstrong or not.

Solution

An Armstrong number of three digits is an integer such that the sum of the cubes of its digits is equal to the number itself. For example, 371 is an Armstrong number since 3**3 + 7**3 + 1**3 = 371.
To know more about Amstrong number visit the references below.
To understand this program you need to know the following:
Function definition in Matlab
For loop in matlab
num2str function in matlab
length function in matlab
str2num function in matlab
logical function in matlab
Find the explanation of the program below the program section

Program


function answer = isamstrong(n)
%this function will give the result if the number is amstrong or not.

%First convert the number to a string to split and check for the condition.
n = num2str(n);

%Create a sum variable to find the sum of the cubes of each digit in the
%number and see if the number is equal to the given number or not.

sum = 0;

%Create a for loop to loop through all the digits and add them up
for i = 1: length(n)
    %Convert the string to number and raise it to the power 3
    %Add the number to the sum and in each loop this will get 
    %Added up and the final result will be there
    sum = sum+ (str2num(n(i)))^3;
end

if sum == str2num(n)
    answer = logical(1);
else
    answer = logical(0);
end

To download the above program in matlab file format then click here: isamstrong.m

Explanation

First we will convert the number to string so that we can split the digits to numbers and then do math on that. For example we will convert the number 123 to '123' so that we will use the n(1) to reference the number 1 and so on to do math.
I have also created a sum variable to find the sum of the cubes of each digit in the number, so that the amstrong number condition is verified.
A for loop is also created to loop through the digits. Remember why we have converted the number to string.
The for loop range is from  1 to length of the number. Digging deep we will understand that the program is converting each digit into number again using the str2num function and cubing it and finally adding it to the sum variable.
So in the first iteration, the sum will be 1, second iteration it will be 9. third iteration it will be 36 in the case of 123 as input. which shows that the number is not amstrong, but for the computer to decide we will use the if else statement.
In the if else statement we will finally convert back the given number from string to number to check if the sum is equal to the given number and if it is answer is true, else it is false.

I think the explanation is easy to understand, but if you have any doubt or if you didn't understand anything, then please do contact me and I will make modifications according to that or will personally explain it to you, so that it will be beneficiary to you and others also. You can contact me by clicking here: Contact me

The above code was high lighted using hilite.me

References:
Amstrong Numbers
Narcissitic Number
What is Amstrong Number - Yahoo Answer

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

Keywords: amstrong number, matlab, if else

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