Friday, 24 April 2015

How to generate a fibonacci series in c# aps.net ?


This is one of the most asked question in interviews, calculating and printing Fibonacci series.
 Here I am writing a program in C# to generate Fibonacci series.The numbers that precedes the series are 0 and 1.The next number is found by adding up the two numbers before it.


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleDemoApp
{
    namespace fibonaciSeries
    {
        class Program
        {
            static void Main(string[] args)
            {

                int i, count, f1 = 0, f2 = 1, f3 = 0;
                Console.Write("Please enter the Limit : ");
                count = int.Parse(Console.ReadLine());
                Console.WriteLine(f1);
                Console.WriteLine(f2);
                for (i = 0; i <= count; i++)
                {
                    f3 = f1 + f2;
                    Console.WriteLine(f3);
                    f1 = f2;
                    f2 = f3;
                }
                Console.ReadLine();

            }
        }
    }

}



Please enter the Limit : 6
Output:-
 0
 1
 1
 2
 3
 5
 8
 13
 21


Calculate nth Fibonacci number:


Itreative method
 we can calculating the nth Fibonacci number, we just need to pass the value with the right index.
 We will first have a look at an iterative approach.
 Here we are using an integer array to keep the Fibonacci numbers until n and returning the nth Fibonacci number.


Source code:- 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleDemoApp
{
    namespace fibonaciSeries
    {
        class Program
        {
            static void Main(string[] args)
            {

                int num = 0, NthValue = 0;
                Console.Write("Please enter the nth number : ");
                num = int.Parse(Console.ReadLine());
                NthValue = getNth_fibonaciSeriesNumber(num);
                Console.WriteLine(NthValue);
                Console.ReadLine();

            }
            public static int getNth_fibonaciSeriesNumber(int n)
            {
                //Need to decrement by 1 since we are starting from 0
                int number = n - 1;
                int[] Fib = new int[number + 1];
                Fib[0] = 0;
                Fib[1] = 1;

                for (int i = 2; i <= number; i++)
                {
                    Fib[i] = Fib[i - 2] + Fib[i - 1];
                }
                return Fib[number];
            }
        }
    }
}


 Please enter the nth number: 9
Output:-
 21


Recursive method:-

We can also look for a recursive method. The only thing to consider is, here we need to pass a number less than 1 to get the nth Fibonacci number.

 For example if we want the 5th Fibonacci number then we need to pass 5-1 (in other words 5) as an input (we can also create a pass-through method alternatively)


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleDemoApp
{
    namespace fibonaciSeries
    {
        class Program
        {
            static void Main(string[] args)
            {

                int num = 0, NthValue = 0;
                Console.Write("Please enter the number : ");
                num = int.Parse(Console.ReadLine());
                NthValue = getNth_Fibonacci_Recursive(num);
                Console.WriteLine(NthValue);
                Console.ReadLine();

            }
            public static int getNth_Fibonacci_Recursive(int n)
            {
                if ((n == 0) || (n == 1))
                {
                    return n;
                }
                else
                    return getNth_Fibonacci_Recursive(n - 1) + getNth_Fibonacci_Recursive(n - 2);
            }
        }
    }
}




In the above article I try to explain how to generate  Fibonacciseries and how get nth   Fibonacci in c#. I hope its useful to you. Please post your feedback, question, or comments about this article.

How to check a given number is prime or not in c# asp.net?

Defintion 

A prime number is a natural number greater than 1 that has no positive divisors other than 1 and itself. 

Here is a c# source code to check a given number is prime or not:-

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ConsoleDemoApp
{
    class test
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Enter a number to check its a prime :-");
            int num = Convert.ToInt32(Console.ReadLine());
            int result = CheckFor_Prime(num);
            if (result == 0)
            {
                Console.WriteLine("{0} is not a prime number!", num);
            }
            else
            {
                Console.WriteLine("{0} is  a prime number", num);
            }
            Console.Read();
        }
        private static int CheckFor_Prime(int number)
        {
            int i;
            for (i = 2; i <= number - 1; i++)
            {
                if (number % i == 0)
                {
                    return 0;
                }
            }
            if (i == number)
            {
                return 1;
            }
            return 0;
        }
    }
}

Ouput:-

Enter a number to check its a prime :- 67
67 is not a prime number!


Enter a number to check its a prime :-77
77 is a prime number

Enter a number to check its a prime :- 29
29 is not a prime number!


Here is a source code example to print prime number between 1 and 100 :-

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ConsoleDemoApp
{
    class test
    {
        static void Main(string[] args)
        {
            bool isPrimeNum = true;
            Console.WriteLine("Prime Numbers between 1 and 100 are:- ");
            for (int i = 2; i <= 100; i++)
            {
                for (int j = 2; j <= 100; j++)
                {

                    if (i != j && i % j == 0)
                    {
                        isPrimeNum = false;
                        break;
                    }

                }
                if (isPrimeNum)
                {
                    Console.Write("\t" + i);
                }
                isPrimeNum = true;
            }
            Console.ReadKey();
        }
    }
}

Outtput:-


Prime Numbers : 
      2 3 5 7 11 13 17 19 23 29
31 37 41 43 47 53 59 61 67 71
73 79 83 89 97