KEMBAR78
UNIT 1 DSA Array_datastructureand algorithms.pptx
Array
4
• Definition :
“An array is a finite ordered collection of
homogeneous data elements which provides
direct access (or random access) to any of its
elements.
An array as a data structure is defined as a set of
pairs (index,value) such that with each index a
value is associated.
• index — indicates the location of an element in an
array.
• value - indicates the actual value of that data
element.
Declaration of an array in ‘C++’:
• int Array_A[20];
Array
• Array Representation
• Arrays can be declared in various ways in different languages.
For illustration, let's take C array declaration.
• As per the above illustration, following are the important points to
be considered. 2
Array
3
• Array Representation
• Index starts with 0.
• Array length is 10 which means it can store 10 elements.
• Each element can be accessed via its index. For example, we
can fetch an element at index 6 as 9.
• Basic Operations
• Following are the basic operations supported by an array.
• Traverse − print all the array elements one by one.
• Insertion − Adds an element at the given index.
• Deletion − Deletes an element at the given index.
• Search − Searches an element using the given index or by the
value.
• Update − Updates an element at the given index.
X(Base
)
X+1
7
Fig 2.1 Memory
Representation
Memory Representation and Calculation
FDS 7
 The address of the ith element is calculated
by the following formula
(Base address) + (offset of the ith element from
base address)
Here, base address is the address of the first
element where array storage starts.
ADDRESS CALCULATION
FDS 8 8
2
• ADT is useful tool for specifying the logical
properties of a data type.
• A data type is a collection of values & the set
of operations on the values.
• ADT refers to the mathematical concept that defines
the data type.
• ADT is not concerned with implementation but is
useful in making use of data type.
Abstract Data Type
• Arrays are stored in consecutive set of
memory locations.
• Array can be thought of as set of index and
values.
• For each index which is defined there is a
value associated with that index.
• There are two operations permitted on array
data structure .retrieve and store
ADT for an array
• CREATE()-produces empty array.
• RETRIVE(array,index)->value
Takes as input array and index and either
returns appropriate value or an error.
• STORE(array,index,value)-array used to enter new
index value pairs.
ADT for an array
Representation and analysis Type
variable_name[size]
Operations with arrays:
Delete
Insert
Update
Search
Sort
Merging of sorting arrays.
Introduction to arrays
Copy operation
#include <stdio.h>
int main()
{
int a[10] = { 3, 6, 9, 2, 5 }, n = 5;
int b[n], i;
// copying elements from one array to another
for (i = 0; i < n; i++)
{
b[i] = a[i];
}
// displaying first array before
// copy the elements from
// one array to other
printf("The first array is :");
for (i = 0; i < n; i++) {
printf("%d ", a[i]);
}
/
// displaying array after copy the elements from one array to other
printf("nThe second array is :");
for (i = 0; i < n; i++)
{
printf("%d ", b[i]);
}
return 0;
}
Output The first array is :3 6 9 2 5
The second array is :3 6 9 2 5
int main()
{
int array[100], position, i, n;
printf("Enter number of elements in arrayn");
scanf("%d", &n);
printf("Enter %d elementsn", n);
for ( i = 0 ; i < n ; i++ )
scanf("%d", &array[i]);
printf("Enter the location where you wish to delete elementn");
scanf("%d", &position);
#•
Delete operation
for ( i = position ; i < n; i++ )
{
array[i] = array[i+1];
}
printf("Resultant array isn");
for( i = 0 ; i < n-1 ; i++)
printf("%dn", array[i]);
return 0;
}
Delete operation
#include <stdio.h>
int main()
{
int array[100], position, i, n, value;
printf("Enter number of elements in arrayn");
scanf("%d", &n);
printf("Enter %d elementsn", n);
for (i= 0;i< n; i++)
scanf("%d",&array[i]);
printf("Enter the location where you wish to insert an elementn");
scanf("%d", &position);
printf("Enter the value to insertn");
scanf("%d", &value);
Inserting an element
for (i = n-1 ; i <=position ; i--)
array[i+1] = array[i];
array[position] = value;
printf("Resultant array isn");
for (i= 0; i < n; i++)
printf("%dn", array[i]);
return 0;
Inserting an element
Sort an array
#include <stdio.h>
void main ()
{
int num[20];
int i, j, temp, n;
printf("enter number of elements in an array
");
scanf("%d", &n);
printf("Enter the elements");
for (i = 0; i < n; ++i)
scanf("%d", &num[i]);
for (i = 0; i < n; ++i){
for (j = i + 1; j < n; ++j){
if (num[i] > num[j]){
temp = num[i];
num[i] = num[j];
num[j] = temp;
}
}
}
printf("The numbers in ascending order is:");
for (i = 0; i < n; ++i)
{
printf("%d", num[i]);
}
}
enter number of elements in an array
5
Enter the elements
12
23
89
11
22
The numbers in ascending order is:
11
12
22
23
89
Reverse array
#include <stdio.h>
int main() {
int array[100], n, i, temp, end;
scanf("%d", &n);
end = n - 1;
for (i = 0; i < n; i++)
{ scanf("%d",
&array[i]);
}
for (i= 0; < n/2; i++)
{
temp = array[i];
array[i] = array[end];
array[end] = temp;
end--;
}
printf("Reversed array elements are:
n"); for ( i= 0; i < n; i++) {
printf("%dn", array[i]);
}
return 0;
Sort element using array
int a[10]={5,4,3,2,1}
for(i=0;i<n;i++)
for(j=i+1;j<n;j++)
{
if(a[i]>a[j])
{
temp=a[i];
a[i]=a[j];
a[j]=temp;
}
}
Merging of two arrays :
#include <stdio.h>
int main()
{
int n1,n2,n3; //Array Size Declaration
int a[100], b[100], c[200];
printf("Enter the size of first array: ");
scanf("%d",&n1);
printf("Enter the array elements: ");
for(int i = 0; i < n1; i++)
scanf("%d", &a[i]);
printf("Enter the size of second array: ");
scanf("%d",&n2);
printf("Enter the array elements: ");
for(int i = 0; i < n2; i++)
scanf("%d", &b[i]);
n3 = n1 + n2;
for(int i = 0; i < n1; i++)
c[i] = a[i];
for(int i = 0; i < n2; i++)
c[i + n1] = b[i];
printf("The merged array: ");
for(int i = 0; i < n3; i++)
printf("%d ", c[i]); //Print the merged array
printf("nFinal array after sorting: ");
for(int i = 0; i < n3; i++)
{
int temp;
for(int j = i + 1; j < n3; j++)
{
if(c[i] > c[j])
{
temp = c[i];
c[i] = c[j];
c[j] = temp;
}
}
}
for(int i = 0; i < n3 ; i++) //Print the sorted Array
printf(" %d ",c[i]);
return 0;
}
• Array - VisuAlgo
Two-dimensional Arrays in C
• multidimensional array is the two-dimensional
array
• type arrayName [ x ][ y ];
Two-dimensional Arrays in C
m-no of rows
n-no of
columns
Printf(“n Enter the rows and
columns”); Scanf(%d %d”,&m,&n);
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
Printf(“n Enter the value of(%d)
(%d)=“,i,j); Scanf(“%d”,&a[i][j]);
}
}
for(i=0;i<m;i+
+)
•{
•Printf(“n”); for(j=0;j<n;j++)
•{
•printf(“%d”,&a[i][j]);
•}
•}
Calculate the address of any element in the 2-D array:
The 2-dimensional array can be defined as an array of arrays. The 2-
Dimensional arrays are organized as matrices which can be
represented as the collection of rows and columns as array[M][N]
where M is the number of rows and N is the number of columns.
Example:
2-D array
To find the address of any element in a 2-Dimensional array there are
the following two ways-
1.Row Major Order
2.Column Major Order
1. Row Major Order:
Row major ordering assigns successive elements, moving
across the rows and then down the next row, to successive
memory locations. In simple language, the elements of an
array are stored in a Row-Wise fashion.
To find the address of the element using row-major order uses
the following formula:
Address of A[I][J] = B + W * ((I – LR) * N + (J – LC))
I = Row Subset of an element whose address to be found,
J = Column Subset of an element whose address to be found,
B = Base address,
W = Storage size of one element store in an array(in byte),
LR = Lower Limit of row/start row index of the matrix(If not
given assume it as zero),
LC = Lower Limit of column/start column index of the matrix(If
not given assume it as zero),
N = Number of column given in the matrix.
Example: Given an array, arr[1………10][1………15] with base value 100 and the size of
each element is 1 Byte in memory. Find the address of arr[8][6] with the help of row-
major order.
Solution:
Given:
Base address B = 100
Storage size of one element store in any array W = 1 Bytes
Row Subset of an element whose address to be found I = 8
Column Subset of an element whose address to be found J = 6
Lower Limit of row/start row index of matrix LR = 1
Lower Limit of column/start column index of matrix = 1
Number of column given in the matrix N = Upper Bound – Lower Bound + 1
= 15 – 1 + 1
= 15
Formula:
Address of A[I][J] = B + W * ((I – LR) * N + (J – LC))
Solution:
Address of A[8][6] = 100 + 1 * ((8 – 1) * 15 + (6 – 1))
= 100 + 1 * ((7) * 15 + (5))
= 100 + 1 * (110)
Address of A[I][J] = 210
Multi-dimensional Arrays inC
• type name[size1][size2]...
[sizeN];
Two-dimensional Arrays in C
• multidimensional array is the two-dimensional array
• type arrayName [ x ][ y ];
Two-dimensional Arrays
HOW TO INITIALIZE 2-D
ARRAY IN PROGRAM
• Initializing Two-Dimensional Arrays
int a[3][4] = { {0, 1, 2, 3} , /* initializers for
{4, 5, 6, 7} ,
{8, 9, 10, 11} /* initializers for row
/* initializers for row indexed by 2 */ };
• Accessing Two-Dimensional Array Elements
int val = a[2][3];
Characteristics of array
38
FDS
An array is a finite ordered collection of homogeneous data
elements.
In array, successive elements of list are stored at a
fixed distance apart.
Array is defined as set of pairs-( index and value).
Array allows random access to any element
deletion of element
in
In array, insertion
and between positions
• requires data
movement. static allocation, which
means space once during
compile time, can not be
Array
provides
allocationdone
changed run
Advantage of Array Data Structure
39
FDS 5
6
Arrays permit efficient random access in constant time
0(1).
Arrays are most appropriate for storing a fixed amount of
data and also for high frequency of data retrievals as
data can be accessed directly.
Wherever there is a direct mapping between the elements
and there positions, arrays are the most suitable data
structures.
Ordered lists such as polynomials are most efficiently
handled using arrays.
Arrays are useful to form the basis for several more
complex data structures, such as heaps, and hash tables
Disadvantage of Array Data
Structure
40
FDS 5
6
Arrays provide static memory management. Hence
during execution the size can neither be grown nor
shrunk.
Array is inefficient when often data is to inserted or
deleted as inserting and deleting an element in array
needs a lot of data movement.
Hence array is inefficient for the applications, which
very often need insert and delete operations in
between.
Applications of Arrays
41
FDS 5
6
Although useful in their own right, arrays also form
the basis for several more complex data structures,
such as heaps, hash tables and can be used to
represent strings, stacks and queues.
All these applications benefit from the compactness
and direct access benefits of arrays.
Two-dimensional data when represented as Matrix and
matrix operations.
93
FIND SIMPLE TRANSPOSE OF
MATRIX
#include <iostream>
using namespace std;
int main()
{
int a[10][10],
trans[10][10], r, c,
i, j;
cout << "Enter
rows and columns
of matrix: ";
cin >> r >> c;
//Storing element of matrix enter by user in array a[][].
cout << endl << "Enter elements of matrix: " << endl;
for(i = 0; i < r; ++i)
for(j = 0; j < c; ++j)
{
cout << "Enter elements a" << i + 1 << j + 1 << ":
}
// Displaying the matrix a[][]
cout << endl << "Entered Matrix: " << endl;
for(i = 0; i < r; ++i)
for(j = 0; j < c; ++j)
{
cout << " " << a[i][j];
if(j == c - 1)
cout << endl <<
endl;
}
// Finding transpose of matrix a[][] and storing it
in array trans[][].
for(i = 0; i < r; ++i)
for(j = 0; j < c; ++j)
{
trans[j][i]=a[i][j];
}

UNIT 1 DSA Array_datastructureand algorithms.pptx

  • 1.
    Array 4 • Definition : “Anarray is a finite ordered collection of homogeneous data elements which provides direct access (or random access) to any of its elements. An array as a data structure is defined as a set of pairs (index,value) such that with each index a value is associated. • index — indicates the location of an element in an array. • value - indicates the actual value of that data element. Declaration of an array in ‘C++’: • int Array_A[20];
  • 2.
    Array • Array Representation •Arrays can be declared in various ways in different languages. For illustration, let's take C array declaration. • As per the above illustration, following are the important points to be considered. 2
  • 3.
    Array 3 • Array Representation •Index starts with 0. • Array length is 10 which means it can store 10 elements. • Each element can be accessed via its index. For example, we can fetch an element at index 6 as 9. • Basic Operations • Following are the basic operations supported by an array. • Traverse − print all the array elements one by one. • Insertion − Adds an element at the given index. • Deletion − Deletes an element at the given index. • Search − Searches an element using the given index or by the value. • Update − Updates an element at the given index.
  • 4.
    X(Base ) X+1 7 Fig 2.1 Memory Representation MemoryRepresentation and Calculation FDS 7
  • 5.
     The addressof the ith element is calculated by the following formula (Base address) + (offset of the ith element from base address) Here, base address is the address of the first element where array storage starts. ADDRESS CALCULATION FDS 8 8 2
  • 6.
    • ADT isuseful tool for specifying the logical properties of a data type. • A data type is a collection of values & the set of operations on the values. • ADT refers to the mathematical concept that defines the data type. • ADT is not concerned with implementation but is useful in making use of data type. Abstract Data Type
  • 7.
    • Arrays arestored in consecutive set of memory locations. • Array can be thought of as set of index and values. • For each index which is defined there is a value associated with that index. • There are two operations permitted on array data structure .retrieve and store ADT for an array
  • 8.
    • CREATE()-produces emptyarray. • RETRIVE(array,index)->value Takes as input array and index and either returns appropriate value or an error. • STORE(array,index,value)-array used to enter new index value pairs. ADT for an array
  • 9.
    Representation and analysisType variable_name[size] Operations with arrays: Delete Insert Update Search Sort Merging of sorting arrays. Introduction to arrays
  • 10.
    Copy operation #include <stdio.h> intmain() { int a[10] = { 3, 6, 9, 2, 5 }, n = 5; int b[n], i; // copying elements from one array to another for (i = 0; i < n; i++) { b[i] = a[i]; } // displaying first array before // copy the elements from // one array to other printf("The first array is :"); for (i = 0; i < n; i++) { printf("%d ", a[i]); }
  • 11.
    / // displaying arrayafter copy the elements from one array to other printf("nThe second array is :"); for (i = 0; i < n; i++) { printf("%d ", b[i]); } return 0; } Output The first array is :3 6 9 2 5 The second array is :3 6 9 2 5
  • 12.
    int main() { int array[100],position, i, n; printf("Enter number of elements in arrayn"); scanf("%d", &n); printf("Enter %d elementsn", n); for ( i = 0 ; i < n ; i++ ) scanf("%d", &array[i]); printf("Enter the location where you wish to delete elementn"); scanf("%d", &position); #• Delete operation
  • 13.
    for ( i= position ; i < n; i++ ) { array[i] = array[i+1]; } printf("Resultant array isn"); for( i = 0 ; i < n-1 ; i++) printf("%dn", array[i]); return 0; }
  • 14.
  • 15.
    #include <stdio.h> int main() { intarray[100], position, i, n, value; printf("Enter number of elements in arrayn"); scanf("%d", &n); printf("Enter %d elementsn", n); for (i= 0;i< n; i++) scanf("%d",&array[i]); printf("Enter the location where you wish to insert an elementn"); scanf("%d", &position); printf("Enter the value to insertn"); scanf("%d", &value); Inserting an element
  • 16.
    for (i =n-1 ; i <=position ; i--) array[i+1] = array[i]; array[position] = value; printf("Resultant array isn"); for (i= 0; i < n; i++) printf("%dn", array[i]); return 0;
  • 17.
  • 18.
    Sort an array #include<stdio.h> void main () { int num[20]; int i, j, temp, n; printf("enter number of elements in an array "); scanf("%d", &n); printf("Enter the elements"); for (i = 0; i < n; ++i) scanf("%d", &num[i]); for (i = 0; i < n; ++i){ for (j = i + 1; j < n; ++j){ if (num[i] > num[j]){ temp = num[i]; num[i] = num[j]; num[j] = temp; } } }
  • 19.
    printf("The numbers inascending order is:"); for (i = 0; i < n; ++i) { printf("%d", num[i]); } } enter number of elements in an array 5 Enter the elements 12 23 89 11 22 The numbers in ascending order is: 11 12 22 23 89
  • 20.
    Reverse array #include <stdio.h> intmain() { int array[100], n, i, temp, end; scanf("%d", &n); end = n - 1; for (i = 0; i < n; i++) { scanf("%d", &array[i]); } for (i= 0; < n/2; i++) { temp = array[i]; array[i] = array[end]; array[end] = temp; end--; } printf("Reversed array elements are: n"); for ( i= 0; i < n; i++) { printf("%dn", array[i]); } return 0;
  • 21.
    Sort element usingarray int a[10]={5,4,3,2,1} for(i=0;i<n;i++) for(j=i+1;j<n;j++) { if(a[i]>a[j]) { temp=a[i]; a[i]=a[j]; a[j]=temp; } }
  • 22.
  • 23.
    #include <stdio.h> int main() { intn1,n2,n3; //Array Size Declaration int a[100], b[100], c[200]; printf("Enter the size of first array: "); scanf("%d",&n1); printf("Enter the array elements: "); for(int i = 0; i < n1; i++) scanf("%d", &a[i]); printf("Enter the size of second array: "); scanf("%d",&n2); printf("Enter the array elements: "); for(int i = 0; i < n2; i++) scanf("%d", &b[i]); n3 = n1 + n2; for(int i = 0; i < n1; i++) c[i] = a[i]; for(int i = 0; i < n2; i++) c[i + n1] = b[i];
  • 24.
    printf("The merged array:"); for(int i = 0; i < n3; i++) printf("%d ", c[i]); //Print the merged array printf("nFinal array after sorting: "); for(int i = 0; i < n3; i++) { int temp; for(int j = i + 1; j < n3; j++) { if(c[i] > c[j]) { temp = c[i]; c[i] = c[j]; c[j] = temp; } } } for(int i = 0; i < n3 ; i++) //Print the sorted Array printf(" %d ",c[i]); return 0; }
  • 25.
    • Array -VisuAlgo
  • 26.
    Two-dimensional Arrays inC • multidimensional array is the two-dimensional array • type arrayName [ x ][ y ];
  • 27.
  • 28.
    m-no of rows n-noof columns Printf(“n Enter the rows and columns”); Scanf(%d %d”,&m,&n); for(i=0;i<m;i++) { for(j=0;j<n;j++) { Printf(“n Enter the value of(%d) (%d)=“,i,j); Scanf(“%d”,&a[i][j]); } }
  • 29.
  • 30.
    Calculate the addressof any element in the 2-D array: The 2-dimensional array can be defined as an array of arrays. The 2- Dimensional arrays are organized as matrices which can be represented as the collection of rows and columns as array[M][N] where M is the number of rows and N is the number of columns. Example: 2-D array To find the address of any element in a 2-Dimensional array there are the following two ways-
  • 31.
    1.Row Major Order 2.ColumnMajor Order 1. Row Major Order: Row major ordering assigns successive elements, moving across the rows and then down the next row, to successive memory locations. In simple language, the elements of an array are stored in a Row-Wise fashion. To find the address of the element using row-major order uses the following formula: Address of A[I][J] = B + W * ((I – LR) * N + (J – LC)) I = Row Subset of an element whose address to be found, J = Column Subset of an element whose address to be found, B = Base address, W = Storage size of one element store in an array(in byte), LR = Lower Limit of row/start row index of the matrix(If not given assume it as zero), LC = Lower Limit of column/start column index of the matrix(If not given assume it as zero), N = Number of column given in the matrix.
  • 32.
    Example: Given anarray, arr[1………10][1………15] with base value 100 and the size of each element is 1 Byte in memory. Find the address of arr[8][6] with the help of row- major order. Solution: Given: Base address B = 100 Storage size of one element store in any array W = 1 Bytes Row Subset of an element whose address to be found I = 8 Column Subset of an element whose address to be found J = 6 Lower Limit of row/start row index of matrix LR = 1 Lower Limit of column/start column index of matrix = 1 Number of column given in the matrix N = Upper Bound – Lower Bound + 1 = 15 – 1 + 1 = 15 Formula: Address of A[I][J] = B + W * ((I – LR) * N + (J – LC)) Solution: Address of A[8][6] = 100 + 1 * ((8 – 1) * 15 + (6 – 1)) = 100 + 1 * ((7) * 15 + (5)) = 100 + 1 * (110) Address of A[I][J] = 210
  • 33.
    Multi-dimensional Arrays inC •type name[size1][size2]... [sizeN];
  • 34.
    Two-dimensional Arrays inC • multidimensional array is the two-dimensional array • type arrayName [ x ][ y ];
  • 35.
  • 36.
    HOW TO INITIALIZE2-D ARRAY IN PROGRAM • Initializing Two-Dimensional Arrays int a[3][4] = { {0, 1, 2, 3} , /* initializers for {4, 5, 6, 7} , {8, 9, 10, 11} /* initializers for row /* initializers for row indexed by 2 */ };
  • 37.
    • Accessing Two-DimensionalArray Elements int val = a[2][3];
  • 38.
    Characteristics of array 38 FDS Anarray is a finite ordered collection of homogeneous data elements. In array, successive elements of list are stored at a fixed distance apart. Array is defined as set of pairs-( index and value). Array allows random access to any element deletion of element in In array, insertion and between positions • requires data movement. static allocation, which means space once during compile time, can not be Array provides allocationdone changed run
  • 39.
    Advantage of ArrayData Structure 39 FDS 5 6 Arrays permit efficient random access in constant time 0(1). Arrays are most appropriate for storing a fixed amount of data and also for high frequency of data retrievals as data can be accessed directly. Wherever there is a direct mapping between the elements and there positions, arrays are the most suitable data structures. Ordered lists such as polynomials are most efficiently handled using arrays. Arrays are useful to form the basis for several more complex data structures, such as heaps, and hash tables
  • 40.
    Disadvantage of ArrayData Structure 40 FDS 5 6 Arrays provide static memory management. Hence during execution the size can neither be grown nor shrunk. Array is inefficient when often data is to inserted or deleted as inserting and deleting an element in array needs a lot of data movement. Hence array is inefficient for the applications, which very often need insert and delete operations in between.
  • 41.
    Applications of Arrays 41 FDS5 6 Although useful in their own right, arrays also form the basis for several more complex data structures, such as heaps, hash tables and can be used to represent strings, stacks and queues. All these applications benefit from the compactness and direct access benefits of arrays. Two-dimensional data when represented as Matrix and matrix operations.
  • 43.
    93 FIND SIMPLE TRANSPOSEOF MATRIX #include <iostream> using namespace std; int main() { int a[10][10], trans[10][10], r, c, i, j; cout << "Enter rows and columns of matrix: "; cin >> r >> c; //Storing element of matrix enter by user in array a[][]. cout << endl << "Enter elements of matrix: " << endl; for(i = 0; i < r; ++i) for(j = 0; j < c; ++j) { cout << "Enter elements a" << i + 1 << j + 1 << ": } // Displaying the matrix a[][] cout << endl << "Entered Matrix: " << endl; for(i = 0; i < r; ++i) for(j = 0; j < c; ++j) { cout << " " << a[i][j]; if(j == c - 1) cout << endl << endl; } // Finding transpose of matrix a[][] and storing it in array trans[][]. for(i = 0; i < r; ++i) for(j = 0; j < c; ++j) { trans[j][i]=a[i][j]; }