Skip to main content

Relationship between 1-Dimensional array and pointer in C programming


                  Array name by itself is an address or pointer. It points to the address of the first element (0th element of an array). Thus, if x is a one dimensional array, then address of the first array element can be expressed as either &x[0] or simple as x. The address of the second array element can be written as either &x[1] or as x+1 and so on. In general, the address of the array element i+1 can be expressed as either &x[i] or as x+i. In the expression x+i, x represents array name (address of first element) whose elements may be integers, characters, float etc and i represents integer quantity. Thus, here x+i specifies an address that is a certain number of memory cells beyond the address of the first array element. Again, x[i] and *(x+i) both represent the content of that address.
     Example:
 To display array element with their address using array name as a pointer.
void main()
{
      int x[5]={2,4,6,8,10}, k;
      printf(“\n element no.      element        address”);
      for(k=0;k<5;k++)
         printf(“\n x[%d]=\t%d %u”,k,*(x+k), x+k);
     
      getch();
      }

  output
Element no.          Element                address
X[0]                                   2                      4056
X[1]                                   4                      4058
X[2]                                   6                      4060
X[3]                                   8                      4062
X[4]                                   10                    4064
         
              In the above program element k acts as the element number and its value varies from 0 to 4. When it is added with an array name ‘x’ i.e. with address of the first element, it points to the consecutive memory location. Thus, element number, element and their addresses are displayed.
 Another example:
           Write a program to calculate average percentage of 10 students in a class using pointer. Read percentage of individual student from user.
Solution:
void main()
  {
  int per[10],i,sum=0;
  clrscr();
  printf("Enter percentage of each student\n");
  for(i=0;i<10;i++)
   {
     scanf("%d",per+i);
     sum+=*(per+i);
   }
  printf("\nThe average is=%d",sum/10);
   getch();

  }

Comments

Popular posts from this blog

Object Oriented Programming

Object Oriented Programming Programming paradigm that represents the concept of "objects" that have data fields (attributes that describe the object) and associated procedures known as methods Programming methodology based on objects, instead of just functions and procedures Focuses on data rather than process As individual objects can be modified without affecting other aspects of the program, it is easier for programmers to structure and organize software programs Easier to update and change programs written in object-oriented languages Simula was the first object oriented programming language Eg: C++, Java, etc. Features of OOPS Objects Referred as instance of class Basic run-time entities in an object-oriented system a person, a place, a bank account, a table of data, etc can be an object They occupy space in memory that keeps its state  Each object contains data and code to manipulate the data  Classes Blue print or prototype  which ...

Passing arrays to functions in C programming

Like any other variables, we can also pass entire array to a function. An array name can be named as an argument for the prototype declaration and in function header. When we call the function no need to subscript or square brackets. When we pass array that pass as a call by reference because the array name is address for that array. /* Program to illustrate passing array to function */ #include<stdio.h> void display(int) ; /* function prototype */ main( ) { int num[5] = {100, 20, 40, 15, 33, i ; clrscr( ) ; printf (“\n The content of array is \n”) ; for (i=0; i<5; i++) display (num[i]) ; /*Pass array element fo fun */ getch{ } ; } void display(int n) { printf (“\t%d”, n ) ; } Output:     The content of array is 100      20       40       15 3 /* Program to read 10 numbers from keyboard to store these num into array and then c...

Recursive Function in C programming

             If a statement within the body of a function calls the same function, the function is called recursive function. Actually, recursion is a process by which a function calls itself repeatedly until some specified condition has been satisfied. This process is used for repetitive computations in which each action is stated in term of previous result. Many iterative or repetitive problems can be written in this form.                To solve a problem using recursive method, two conditions must be satisfied. They are: 1)       Problem could be written or defined in term of its previous result. 2)       Problem statement must include a stopping condition. /*   An example of recursive function to calculate factorial of a number.*/    #include<stdio.h>    #include<conio.h...