Module 3
Module 3
Module 3: Functions
Every C program should consist of one or more functions. Among these functions main ( )
function is compulsory. All programs start execution from main ( ) function.
Functions: Functions are independent program modules that are designed to carry out a
particular task.
A large program can be divided into manageable pieces called modules where each module does
a specific task. Thus, the functions often called modules are self-contained small programs that
carry out some specific, well defined tasks. Functions act like building blocks using which any
desired activity can be performed by combining one or more function.
    main ()
    {                                                                           func1 ()
      -------------------                                                       {
      -------------------                                                         Statement block;
      func1 ();                                                                 }
        return 0;
    }
             From the figure we see that main () calls the function named func1().Therefore , main 0 is
              Known as the calling function and func1() is known as the called function.
             The moment the compiler encounters a function call, instead of executing the next
              statement in the calling function, the control jumps to the statements that are a part of the
              called function. After the called function is executed, the control is returned back to the
              calling program.
             It is not only the main () function that can call other function. A function can call any
              other function. One function calling another and this function in turn calling some other
              function.
Advantages of function:
The existing function can be re-used as building blocks to create new programs. This results in
reduced program size .These functions can be used any number of time.
Programs can be written easily and we can keep track of what each function is doing.
A large program is divided into smaller sub programs so that each sub program performs a
specific task. This approach makes the program development more manageable.
Easier debugging:
Using modular appoarch, localizing, locating and isolating a faulty function is much easier.
Function sharing:
#include<stdio.h>
void add()
int a,b,sum;
n”); scanf(“%d%d”,&a,&b);
                                                   lOMoARcPSD|49216110
sum=a+b;
printf(“%d”,sum);
return;
void main()
add();
return;
         After the declaration of every function there should be a semicolon. if the semicolon is
          missing ,the compiler will generate an error message.
         The function declaration is gobal.Therefore the declared function can be called from Any
          point in the program.
         A function called be declared within the body of another function.
         A function having void as its return type cannot return any value.
                                                   lOMoARcPSD|49216110
        A function having void as its parameter list cannot accept any value. So the function
         declared as
                  void print(void); or void print();
        if the function declaration does not specify any return type, then by default, the function
         returns an integer value. Therefore when a function is declared as
        Then the function sum() accepts two integer values from the calling function and in turn
         returns n integer value to the caller.
        Some compiler makes it compulsory to declare the function before its usage while other
         compilers make it optional. However, it is good to always declares make function before
         its usage as it allows error checking on the arguments in the function call.
     NOTE: the variable names used in the function prototype and the variable names used in
     function definition can be different. But the number of parameters type of parameters and the
     order of parameters must be same.
Function definition:
 The program module that is written to achieve a specific task is called function definition.
 Each function definition consists of two parts. Namely:
       Function header
       Function body
 Syntax:
 }
                                                lOMoARcPSD|49216110
  Note: The first line function_type function_name(parameter list) is known as the function
  header and thestatements within opening and closing braces is known as the function body.
     i.   Function Header: It consists of three parts: Function type, function name and
  list of paraemeters.The semicolon is not present at the end of header.
     Function type:
      The function type specifies the type of value that the function is expected to
       return to the callingfunction.
      If the return type or function type is not specified, then it is assumed as int.
      If function is not returning anything, then it is void.
  Function name: The function name is any valid C identifier and must follow same rules
  as of othervariable.
  List of Parameters: The parameter list declares the variables that will receive the data
  sent by the callingprogram which serves as input and known as Formal Parameter List.
     ii. Function Body: The function body contains the declarations and statements
  necessary forperforming the required task. The body is enclosed in braces, contains
  three parts:
The number and order of arguments in the function header must be same as that given in the
function declaration statement.
The function header is same as that of the function declaration. The only difference between the
two is that list of variables is not followed by semicolon. The list of variables in the function
header is known as the formal parameters list. The parameter list may have zero or more
parameters of any data type. The function body contains instructions to perform the desired
computation in a function.
Function call:
The function call statement invokes the function. When a function is invoked the compiler jumps
to the called function to execute the statements that are a part of that function.
Syntax:
Example:
#include<stdio.h>
int main()
int num1,num2,total=0;
number:=”); scanf(“%d”,&num1);
:”); scanf(“%d”,&num2);
printf(“\n total=%d”,total);
{ //FUNCTION BODY
int result;
    result=a+b;
                                             lOMoARcPSD|49216110
return result;
Output:
    Enter the first number: 20
    Enter the second number:
    10
Formal parameter: The variables defined in the function header of function definition are
called formal parameters. All the variables should be separately declared and each declaration
must be separated by commas.
Actual parameter: the variables that are used when a function is invoked are called actual
parameters. Using the actual parameters the data can be transferred to the function. The
corresponding formal parameters in the function definition receive them. The actual parameters
and formal parameters must match in number and type of data.
Example:
#include<stdio.h>
return a+b;
void main()
int m,n,res;
scanf(“%d %d”,&m,&n);
printf(“%d %d %d”,m,n,res);
return;
                                                 lOMoARcPSD|49216110
Actual parameters are used in calling function                         Formal parameters are used in the function
when a function is invoked.                                            header of a called function.
Example: Example:
Actual parameters can be constants, variables                          Formal parameters should be only variables.
or expressions.                                                        Expressions and constants.
Example: Example:
Actual parameter sends values to the formal                            Formal parameters receive values from the
parameters.                                                            actual parameters.
Example: Example:
Pass by value:
In pass by value the values of actual parameters are copied into formal parameters i.e formal
parameters contain only the copy of actual parameters. So, even if the values of the formal
parameters changes in the called function, the values of the actual parameters are not changed.
Advantage:
Disadvantage:
      It does not allow information to be transferred back to calling function via arguments.
       Thus, pass by value is restricted to one-way transfer of information from calling function
       to called function.
Example:
  #include<stdio.h>
  void swap( int m,int
  n)
  {
         int temp;
         m=n;
         n=temp;
  }
  void main()
  {
         int a,b;
         a=10,b=20;
         swap(a,b);
         printf(“”a=%d and b=%d\n”,a,b);
  }
Output:
a=10,b=20
                                              lOMoARcPSD|49216110
NOTE: In pass by value any change done on formal parameters will not have any effect on
actual parameters.
Pass by reference:
In pass by reference when a function is called the address of actual parameters are sent. In the
called function, the formal parameters should be declared as pointers with the same type as the
actual parameters. The addresses of actual parameters are copied into formal parameters. Using
these addresses the values of the actual parameters can be changed. This way of changing the
actual parameters indirectly using the address of actual parameters is called pass reference.
Example:
   #include<stdio.h>
   void swap( int *m,int* n)
   {
          int temp;
          temp=*m;
          *m=*n;
          *n=temp;
   }
   void main()
   {
          int a,b;
          a=10,b=20;
          swap(&a,&b);
          printf(“”a=%d and b=%d\n”,a,b);
   }
Output:
a=20,b=10
will not affect the actual parameters in                                  formal parameters indirectly manipulate
the calling function.                                                     the actual parameters.
Execution is slower since all the values have                             Execution is faster since only addresses
to be copied into formal parameters.                                      are copied.
Transfer of information is possible only in one                           Even though only one value can be returned
direction i.e from calling function to the called                         using return statement, though the
function.                                                                 parameters we can send the values to actual
                                                                          parameters.Here,two way communication is
                                                                          possible.
Storage classes:
    The storage class of a variable defines the scope and lifetime of variables and/or
      functions declared within a C program.
    The storage class of a function or a variable determines the part of memory where
      storage space will be allocated for that variable or function.
    It specifies how long the storage allocation will continue to exist for that function or
      variable.
      Syntax of storage class:
      Storage class
The various storage classes in C language are classified as:
   1. Automatic(local variable):
      Local variables are the variables which are defined within a function. These variables are
      also called automatic variables. All variables must be defined before the first executable
      in the function. Whenever control enters into the function memory is allocated for the
      local variables and whenever control goes out of the function memory will de-allocated.
      That is the reason the local variables cannot be accessed by any other function. The local
      variables have the following feature:
      These variables cannot be accessed by any function and are alive and active within the
      function.
            The scope of these variables is limited only to the function in which they are
              declared and cannot be accessed outside the function.
           No other function can use a local variable and change its value.
           The auto is the default storage class for all local variables.
       Example:
                                            lOMoARcPSD|49216110
           #include <stdio.h>
           void func1()
           {
                   int a=10;
                   printf(“\n a =%d”,a);//auto integer local variable
           }
           void func2()
           {
                   int a=20;
           print(“\n a =%d”,a);//auto integer local to func2()
           }
           void main()
           {
                   int a=30; //auto integer local to main()
                   func1();
                   func2();
                   printf(“\n a =%d”,a);
           }
2. Static:
   Static the default storage class for global variables. The variable that are declared using
   the keyword static are called static variable. The static variable can be declared outside
   the function or within the function. They have the characteristic of both local and global
   variable. The declaration of static variable should begin with the keyword static.
3. Register :
       When a variable is declared using register as the storage class. It is stored in a
          CPU register instead of RAM .since the variable is stored in RAM, the maximum
          size of the variable is equal to the register size.
       One drawback of using a register variable is that they cannot be operated using
          the unary‟&‟ operator because it does not have a memory location associated
          with it.
                                             lOMoARcPSD|49216110
Example:
           #include<stdio.h>
           int exp(int a,int b);
           main()
           {
                   int a= 3,b=5,res;
                   res=exp(a,b);
                   printf(“\n%d to the power of %d=%d”,a,b,res);
                   getch();
                   return 0;
           }
           int exp(int a,int b)
           {
                   Register int res=1;
                   int i; for(i=1;i<b;i+
                   +) res=res*b;
                   return res;
           }
       Out put:
       3 to the power of 5=243
4. Extern :
   The extern storage class is used to give reference of a global variable that is visible to all
   the program files. Such global variables are declared like any other variable in one of the
   program file. When there are multiple files in a program and you need to use a particular
   function or variable in a file apart from which it is declared then use the keyword extern.
                                             lOMoARcPSD|49216110
Example:
          int x;
          Void print(void);
          int main()
          {
                 x=10;
                 printf(“\n x in FILE1=%d”,x);
                 print();
                 return 0;
          }
          #include<stdio.h>
          extern int x;
          void print()
          {
          Printf(“\ x in FILE2=%d”,x);
          }
          main()
          {
                  Statements;
          }
Output:
          X in FILE1=10
          X in FILE 2=10
                                               lOMoARcPSD|49216110
Categories of function:
Based on parameters and return value the functions are categorized as
   1. Function with no parameters and no return value
       This category is also called “void function with no parameters”. In this category, there is
       no data transfer between the calling function and called function.so, calling function
       cannot send values and called function cannot receive the data.
       Example :
                                            lOMoARcPSD|49216110
   Example :
                                           lOMoARcPSD|49216110
Example :
   Return statement:
       The return statement is used to terminate the execution of a function and returns
         control to the calling function. When this statement is encountered the program
                                          lOMoARcPSD|49216110
       execution resumes in the calling function at the point immediately following the
       function call.
 A return statement may or may not return a value to the calling function.
Example:
  #include<stdio.h>
  #include<conio.h>
  int check-relation(int a,int
  b); main()
  {
          int a=3,b=5,res;
          res=check_relation(a,b);
          if(res==0)
          printf(“\n EQUAL””);
          if(res==1)
          printf(“\n a is greater than b”);
          if(res==-1)
          printf(“\n a is less than b”);
          getch();
          return 0;
  }
  int check_relation (int a, int b)
  {
          if(a==b)
          return 0;
          if(a>b)
          return 1;
          else if (a<b)
          return -1;
  }
Output:
 a is less than b
                                                lOMoARcPSD|49216110
Scope of variables:
The accessibility and visibility of the variables at different point in the program.
A variable or a constant in c has four types of scope: block, function, file and program scope.
       Block scope:
      The statement block is a group of statements enclosed within opening and closing curly
       brackets({}).If a variable is declared within a statement block then ,as soon as the control
       exits that block, the variable will cease to exit. Such a variable also known as a local
       variable is said to have a block scope.
Example:
          #include <stdio.h>
          int main()
          {
                 int x=10;
                 int i=0;
                 printf(“\n the value of x outside the while loop is %d”,x);
                 while(i<3)
                 {
                          int x=i;
                          printf(“\n the value of x inside the while loop is %d
          ”,x);
                          i++;
                 }
                 printf(“\n the value of x outside the while loop is %d ”,x);
                 return 0;
                 }
       Output:
           the value of x outside the while loop is 10
           the value of x inside the while loop is 0
           the value of x inside the while loop is 1
           the value of x inside the while loop is 2
           the value of x outside the while loop is 10
       Function scope:
      Function scope indicates that a variable is active and visible from the beginning to the
       end of a function.
      In C only the goto label has function scope. In other words function scope is applicable
       only with goto label names. This means that the programmer cannot have the same label
       name inside a function.
                                                  lOMoARcPSD|49216110
Example:
  int main()
  {
return 0;
     In this example, the label loop is visible from the beginning to the end of the main()
      function. There should not be more than one label having the same name within the main
      () function.
Example:
         #include<stdio.h>
         int x=10;
         void print();
         int main()
         {
                 printf(“\n the value of x in main()=%d”,x);
                 int x=2;
                 printf(“\n the value of local variable x in main()=%d”,x);
                 print();
                 return 0;
         }
         void print()
         {
                 printf(“\n the value of x in print()=%d”,x);
         }
      Output:
         The value of x in main()=10
         The value of local variable x in main()=2
         The value of x in print()=10
                                                lOMoARcPSD|49216110
       File scope:
      Global variable is accessible until the end of the file , the variable is said to have file
       scope.To allow a variable to have file scope, declare that variable with the static
       keyword before specifying its data type.
      A global static variable can be used anywhere from the file in which it is declared but it is
       not accessible by any other files.
   Example:
      Static int x =10;
Recursive functions:
    A recursive function is defined as a function that calls itself to solve a smaller version of
      its task until a final call is made which does not require a call to itself. Every recursive
      solution has two major cases they are:
    Base case: The problem is simple enough to be solved directly without making any
      further calls to the same function.
    Recursive case: The problem at hand is divided into simpler sub parts. Second the
      function calls itself but with subparts of the problem obtained in the first step. Third the
      result is obtained by combining the solution of simpler sub-parts.
    Recursion is defining large and complex problem s in terms of a smaller and more easily
      solvable problem. In recursive function, a complex problem is defined in terms of simpler
      problems and the simplest problem is given explicitly.
#include<stdio.h>
main()
{
         int num;
         printf(“\n enter the number:”);
         scanf(“%d”,&num);
         printf(“result=%d”,fact(num));
}
int fact(int n)
{
         if(n==0) or (n==1)
return 1;
else
return n*fact(n-1);
}
      Base case is when n=1 or n=0 because if n=1 or n=0 the result will be 1
      Recursive case of the factorial function will call itself but with a smaller value of n,this
                                       lOMoARcPSD|49216110
Finding exponent:
#include<stdio.h>
int exp_rec(int,int);
main()
{
        int num1,num2,res;
        printf(“\n enter the two
        numbers:”); scanf(“%d
        %d”,&num1,&num2);
        res=exp_rec(num1,num2); printf(“\
        n result=%d”,res);
        return 0;
}
int exp_res(int x,int y)
{
        if(y==0)
        return 1;
        else
        return (x* exp_rec(x,y-1));
}
Types of recursion:
Recursion is a technique that breaks a problem into one or more sub-problems that are similar to
the original problem.
Any recursive function can be categorized based on the following:
     Whether the function calls itself directly or indirectly(direct or indirect recursion)
     Whether any operation is pending at each recursive call(tail-recursion or not)
     The structure of the calling pattern(linear or tree recursion)
1. Direct recursion:
Example:
          int Func(int n)
          {
                 if(n==0)
                 return n;
                 return(Func(n-1));
          }
Here the function Func() calls itself for all positive values of n, so it is said to be a directly
recursive function.
    2. Indirect Recursion:
                                                  lOMoARcPSD|49216110
Example:
         int Func1(int n)
         {
                 if(n==0)
                 return n;
                 return Func2(n);
         }
         int Func2(int x)
         {
         return Func1(x-1);
         }
3. Tail recursion:
         int Fact(int n)
         {
                 if(n==1)
                 return 1;
                 return (n*fact(n-1));
         }
                                       Module 3: ARRAYS
DEFINITION: An array is a collection of similar (homogeneous) data elements .these data
elements have the same data type. The elements of the array are stored in consecutive
memory locations and are referenced by index (also known as subscripts).
Types of Array:
   1. Single dimensional array: the array with one set of square [] are single
      dimensional arrays.
      Example: int a[10];
   2. Two dimensional array: The array with two sets of square brackets [][] are called 2-
      dimensional array.
      Example: int b[10][10];
   3. Multi dimensional array: array with two or more dimensions are called
      multi- dimensional arrays.
      Example: int c[3][4]
An array must be declared before being used. Declaring an array means specifying three things:
      Data Type: What kind of value it stores. For example: int, char, float, double.
      Array Name: To identify the array.
      Size: The maximum number of values that the array can hold.
Syntax:
      Here type can be int, float, double or char any other valid data type. The number within
       brackets indicates the size of the array, i.e the maximum number of elements that can
       be stored in the array.
      The size of array is constant and must have a value at compilation time.
Example:
       int marks[10];
                                               lOMoARcPSD|49216110
braces
 The integer expression enclosed within brackets must end with semicolon.
       For accessing an individual element of the array, the array subscripts must be used.
       We can access the first element of array as a[0].
                a        10     20       30 40 50
                          0     1        2 3   4
We calculate the address of any element in the array using the following simple formula:
Element address=1000+2*3=1006
Example program:
The first elements of array marks[5] can accessed by writing marks[0].Now to process all the
elements of the array, we will use a loop.
1 int i, marks[10];
for (i=0;i<10;i++)
marks [i]=-1;
Output:
                                                  lOMoARcPSD|49216110
Problem1:
Problem 2:
Solution:
To store values in array, there are three ways: first to initialize the array element, second to
input a value for every individual element, third to assign value to the elements.
                                                lOMoARcPSD|49216110
1 .Initialization of array:
       Elements of the array can also be initialized at the time of declaration as in the case
        of every other variable.
       When an array is initialized ,we need to provide a value for every element in the array
        .Array are initialized by writing:
        Syntax:
The values are written with curly brackets and every value is separated by a comma.
       This statement is absolutely legal. Here the compiler will allocate enough space for all
        initialized elements. If the number of value provided is less than the number of
        elements in the array, the un-assigned elements are filled with zeros.
                                                lOMoARcPSD|49216110
2. Assigning values:
The third way to assign values to individual elements of the array is by using the assignment
operator. Any value that evaluates to an appropriate data type as that of the array can be assigned
to the individual array element. A simple assignment statement can be written as,
Marks[3]=100;
Here , 100 is assigned to the fourth element of the array which is specified as marks[3].
                                                lOMoARcPSD|49216110
Length of the array is given by the number of elements stored in it.the general formula to
calculate the length of the array is,
Where upper bound is the index of the last element and lower bound is the index of the
first element in the array.
Solution:
1 Traversal
2. Deletion
3. Insertion
4. Search
5. Sorting
6. Merging
1. Traversal:
Traversing the array element means accessing each and every element of the array for a specific
purpose. We have already seen this while reading about accessing array elements.
                                                 lOMoARcPSD|49216110
If A is an array of homogenous data elements, then traversing the data elements can include
printing very element, counting the total number of elements, or performing any process on these
elements. Since an array is a linear data structure, traversing its elements is very simple and
straightforward.
Insertion:
Inserting an element in the array means adding a new data element in an already existing array. If
the element has to be inserted at the end o the existing array, then the task of insertion is quite
simple. We just have to add 1 to the upper bound and assign the value. Here we assume that the
memory space allocated for the array is still available.
Example:
The array is declared to store marks of all the students in the aclass.now suppose that there are
54 students and a new student comes and is asked to given the same test. The marks of this new
student would be stored in marks [55].assuming that the student secured 68 marks.we will assign
the value as,
marks [55]=68;
                                                lOMoARcPSD|49216110
Solution:
Deletion:
Deleting an element from the array means removing a data element from an already existing
array. If the element has to be deleted from the end of the existing array, then the task of deletion
is quite simple. We just have to subtract 1 from the upper bound.
Example:
int marks[];
      The array is declared to store marks of all the students in the calss.Now suppose there are
       54 students and the student with roll number 54 leaves the course. The marks of this
       student was therefore stored in marks [54].We just have to decrement the upper bound.
       Subtracting 1 from the upper bound will indicate that there are 53 valid data in the array.
      If we have to delete the element from the middle of the array, then this task is not
       trival.We just had to move as much as half of the elements from its position in order to
       occupy the space of the deleted element.
lOMoARcPSD|49216110
                                            lOMoARcPSD|49216110
Merging:
Merging two array in a third array mean first copying the contents of the first array of the
first array into the third array and then coping the contents of the second array into the third
array . Hence, the merge array contains the contents of first array followed by second array
Example:
      Searching means to find whether a particular value is present in the array or not. If the
       value is present in the array then searching is said to be successful and the searching
       process given the location of that value in the array. Otherwise, if the value is not
       present in the array, the searching process displays the appropriate message and in
       this case searching is said to be unsuccessful.
      There are two popular methods for searching the array elements. One is linear search
       and second is binary search.
                                          lOMoARcPSD|49216110
Linear search:
      Linear search also known as sequential search is a very simple, method used for
       searching n array for a particular value. It works by comparing every elements of the
       array one by one in sequence until a match is found.
      Linear search is mostly used to search an unordered list of elements
Example: if an array A[]is declared and initialized as, and VAL=7,then searching means to
find out whether the value „7‟ is present in the array or not .If yes ,then the search is
successful and it returns the position of occurrence of VAL .
int A[]={10,8,2,7,3,4,9,1,6,5};
Solution:
Example:
lOMoARcPSD|49216110
                                           lOMoARcPSD|49216110
Binary search:
      The linear search algorithm is very slow. If we have an array with 1 million entries,
       then to search a value from that array, we would need to make 1 million comparisons
       in the worst case. However if the array is sorted, we have a better and efficient
       alternative, known as binary search.
      Binary search algorithm is a searching algorithm that works efficiently with the sorted
       list. The algorithm finds out the position of a particular element in the array.
Example:
                                          lOMoARcPSD|49216110
Two-dimensional arrays:
A 2D array is specified using two subscripts where one subscript denotes row and other
denotes column consider the 2D array as an array of 1D array.
                                             lOMoARcPSD|49216110
Similar to one dimensional arrays, two –dimensional arrays must be declared before being
used.
The declaration statement tells the compiler the name of the array, the data type of each
element in the array and the size of each dimension.
Syntax:
Example:
int marks[3][5]
 here two dimensional array called marks is declared that has m93) rows and n95) columns.
The first element of the array is denoted by marks[0][0],the second element as marks[0][1],
and so on. Here marks [0][0] stores the marks obtained by the first student in the first subject,
marks[1][0] stores the marks obtained by the second.
Syntax:
Example:
int marks[2][3]={90,87,78,68,62,71};
int marks[2][3]={{90,87,78},{68,62,71}};
                                             lOMoARcPSD|49216110
      The given 2-D array has two rows and 3 columns. Here, the elements in the first row
       are initialized first and then the elements of the second row are initialized.then,
marks[0][0]=90
marks[0][1]=87
marks[0][2]=78
marks[1][0]=68
marks[1][1]=62
marks[1][2]=71
      In the case of 1D array, if the array is completely initialized to, we may omit the size
       of the array. The same concept can be applied to a 2D array, except that the only the
       size of the first dimension can be omitted. Then ,
int marks[][3]={{90,87,78},{68,62,73}};
      In order to initialize the entire 2D array to zero ,simply specify the first value as zero
                           , int marks[2][3]={0};
 In case of 1D array we used a single for loop to vary the index I in every pass, so that all the
elements could be scanned. Similarly, since 2D array contains two subscripts, we will use
two for loops to scan the elements. The first for loop will loop for each row in the 2D array
and the second for loop will scan individual columns for every row in the array.
for(i=0;i<2;i++)
for(j=0;j<2;j++)
printf(“%d”,a[i][j]);
Transpose:
Sum:
         Two matrices that are compatible with each other can be added together by storing
          the result in the third matrix.
         Two matrices are said to be compatible when they have the same number of rows and
          columns.
         Elements of the matrices can be added by writing : Ci,j=Ai,j+Bi,j
Difference:
 Two matrices that are compatible with each other can be subtracted thereby storing the result
 in the third matrix .Two matrices are said to be compatible when they have the same number
 of rows and columns. Elements of the matrices can be subtracted by writing: Ci,j= Ai,j-Bi,j.
Product:
 Two matrices can be multiplied with each other if the number of columns in the first matrix
 is equal to the number of rows in the second matrix. Therefore, m x n matrix A can be
 multiplied with a p x q matrix if n=q.
One-dimensional
                                                                         Passing an entire
                Passing individual
                                                                         array
                elements
The individual elements of an array can be passed to a function either by passing their
addresses or their data values.
The individual elements can be passed in the same manner as we pass value of any other datatype.
The condition is just that the data type of the array element must match the type of the function
parameter.
Example:
main()
int arr[5]=[1,2,3,4,5};
func(arr[3]);
Printf(“%d”,num);
In this example, only one element of the array is passed to the called function. This is done
by using the index expression. i.e arr[3].
Passing Address:
We can pass the address of an individual array element by preceding the address operator (&) to
the element‟s indexed reference. Therefore, to pass the address of the fourth element of the
array to the called function we will write & arr [3].
In the called function value of the array element must be accessed using the indirection
(*) operator.
Example:
                                                lOMoARcPSD|49216110
main()
int arr[5]=[1,2,3,4,5};
func(&arr[3]);
Printf(“%d”,num);
When we need to pass an entire array to a function, we can simply pass the name of the array
main()
int arr[5]=[1,2,3,4,5};
func(arr);
int i ;
for(i=0;i<5;i++)
Printf(“%d”,arr[i]);
             }
                                               lOMoARcPSD|49216110
There are 3 ways of passing parts of the two dimensional array to a function.
      First, we can pass individual elements of the array. This is exactly same as passing the
       elements of a 1 D array.
      Second, we can pass a single row of the 2D array. This is equivalent to passing the entire
       1 D array to function.
      Third, we can pass the entire 2D array to the function.
Passing a Row:
A row of a 2D array can be passed by indexing the array name with the row number. When we
send a single row of a two-dimensional array, then the called function receives one-dimensional
array.
                                                   lOMoARcPSD|49216110
main ()
int arr[5]={{1,2,3},{4,5,6}};
func(arr);
int i ;
for(i=0;i<5;i++)
Printf(“%d”,arr[i]*10);
          To pass a 2D array to a function, we can use the array name as the actual parameter.
          The parameter in the called function must indicate that the array has two dimensions.
A multidimensional array in simple terms is an array of arrays. Like we have one index in a 1 D
array , two indices in a 2D array, in the same way we have n indices in an n-dimensional array
or multidimensional array..