Skip to main content

Generate triangle numbers using matlab function

Problem

To get the nth triangle number then it will be 1+2+3+4+5+......+n, so we can simply say that the sum of natural numbers until a given number will give the triangle number. To know more about triangle numbers please visit wikipedia.com from here: https://en.wikipedia.org/wiki/Triangular_number
Generate triangle numbers upto the given number n. For example if the function is trianglenumbers(n), then trianglenumbers(5) should be [1 3 6 10 15]. Solve using matlab

Solution

Here we have used the for loop to loop through the n numbers to find their sum. Please read about the for loop from the link given if you don't know what for loop is, or how to for loop in matlab
For loop in matlab
Find the explanation for the program below the program section

Program

function result = trianglenumbers(n)
%This function using matlab will generate triangle numbers
%Triangle numbers can simply be called as the sum of the natural numbers
%So the nth trianlge number is 1+2+3+4+5+....+n

%To get a more understanding of triangle numbers visit:
%https://en.wikipedia.org/wiki/Triangular_number

%We wil create a variable to store all the numbers upto 
% n triangle numbers
result = [];

sum = 0;

for i = 1:n
    sum = sum+i;
    result = [result sum];
end

To download the above matlab file click here: trianglenumbers.m

Explanation

In this function first we will create an empty vector to store the values of the triangle numbers generated at each stage of iteration. Now we will create a sum variable to store the sum of the numbers at each stage. Now in the for loop, we will see everything from here iteration by iteration so that you will understand it very easily.

First iteration

During the first iteration, the value of i is 1, now the sum becomes 0+1(sum+i) and the result vector will store the value of the sum at each stage of iteration thus, result = [1], and the first iteration comes to an end, the second iteration starts

Second iteration

During the second iteration the value of i is 2, now the sum becomes 1+2(sum+i) digging deep, the result vector becomes, result = [1 3]([result sum]), now the second iteration comes to an end, the third iteration starts.

Third iteration

Now in the third iteration the value of i is 3, the sum becomes 3+3(sum+3), digging deep into the program, result vector becomes, result = [1 3 6]([result sum]), now the third iteration is over and the fourth iteration starts and this iterations continue until the value of i becomes n.

Finally the output of the function is the result vector which will give all the values of triangle numbers till the number n.

I have tried to explain this function as much as I can so that even the novice programmers will understand it. If you didn't understand this program, then please contact me or comment below so that I will make it more simple and this will benefit all the other people. Thanks.

To download this post and read it offline, you can do download it from here: trianglenumbers.pdf

The above code was formatted using: hilite.me

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

Keywords: triangle numbers, matlab function

Popular posts from this blog

Project Euler Problem 67 Solution with Python

Maximum path sum II By starting at the top of the triangle below and moving to adjacent numbers on the row below, the maximum total from top to bottom is 23. 3 7 4 2 4 6 8 5 9 3 That is, 3 + 7 + 4 + 9 = 23. Find the maximum total from top to bottom in triangle.txt (right click and 'Save Link/Target As...'), a 15K text file containing a triangle with one-hundred rows.

Problem 43 Project Euler Solution with python

Sub-string divisibility The number, 1406357289, is a 0 to 9 pandigital number because it is made up of each of the digits 0 to 9 in some order, but it also has a rather interesting sub-string divisibility property. Let d 1 be the 1 st digit, d 2 be the 2 nd digit, and so on. In this way, we note the following: d 2 d 3 d 4 =406 is divisible by 2 d 3 d 4 d 5 =063 is divisible by 3 d 4 d 5 d 6 =635 is divisible by 5 d 5 d 6 d 7 =357 is divisible by 7 d 6 d 7 d 8 =572 is divisible by 11 d 7 d 8 d 9 =728 is divisible by 13 d 8 d 9 d 10 =289 is divisible by 17 Find the sum of all 0 to 9 pandigital numbers with this property. One might write a simple solution using direct if else statements for this problem. Using if else statements, the execution time may be a few seconds. But this is not a very good approach. I too had written a program with if else statement which will take each and every permutation of the 0-9 Pandigital and check for the conditions given in the qu...

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...