KEMBAR78
Yash Bhargava Array In programming in C | PPTX
NAME:YASH BHARGAVA
CLASS:IT
SEC: “G”
ROLL NO.:06615603124
SUBJECT : PROGRAMMING
IN C
ARRAYS
WHAT IS AN ARRAY?
-In programming, an array is a data structure that
stores a collection of elements of the same data type
in contiguous memory locations, allowing access to
each element using an index.
-It holds a collection of elements, all of which must be
of the same data type (e.g., integers, strings,
booleans).
-The elements are stored in consecutive memory
locations, meaning they are placed one after another
in memory.
SYNTAX FOR DECLARING AND
INITIALIZING AN ARRAY
• Data_type name[size];
• Data_type name[size]={x,y,z,….};//size not required in this
case!
• Data_type name[rows][columns]; //for 2-d arrays
• We can also initialize the array one by one by accessing it
using the index.
• Name[0]=0
PROPERTIES OF ARRAY
• DATA IN AN ARRAY IS STORED IN CONTIGUOUS MEMORY
LOCATIONS.
• EACH ELEMENT OF AN ARRAY IS OF SAME SIZE.
• ANY ELEMENT OF THE ARRAY WITH GIVEN INDEX CAN BE
ACCESSED VERY QUICKLY BY USING ITS ADDRESS WHICH
CAN BE CALCULATED USING THE BASE ADDRESS AND THE
INDEX.
ADVANTAGES OF AN ARRAY
• IT IS USED TO REPRESENT MULTIPLE DATA ITEMS OF SAME
TYPE BY USING ONLY SINGLE NAME.
• ACCESSING AN ITEM IN A GIVEN ARRAY IS VERY FAST
• 2 DIMENSIONAL ARRAYS MAKE IT EASY IN MATHEMATICAL
APLICATIONS AS IT IS USED TO REPRESENT A MATRIX.
DISADVANTAGES OF AN ARRAY
• POOR TIME COMPLEXITY OF INSERTION AND DELETION
OPERATION.
• WASTAGE OF MEMORY SINCE ARRAYS ARE FIXED IN SIZE.
• IF THERE IS ENOUGH SPACE PRESENT IN THE MEMORY BUT
NOT IN CONTIGUOUS FORM, YOU WILL NOT BE ABLE TO
INITIALIZE ARRAY.
• IT IS NOT POSSIBLE TO INCREASE THE SIZE OF THE ARRAY,
ONCE YOU HAVE DECLAREDTHE ARRAY.
TYPES OF ARRAYS:
•1.ONE DIMENSIONAL ARRAYS.
•2.TWO-DIMENSIONAL ARRAYS.
•3.MULTIDIMENSIONAL
ARRAYS.
ONE DIMENSIONAL ARRAYS TWO DIMENSIONAL ARRAYS
• A VARIABLE WHICHREPRESENT THE LIST OF ITEMS
USING ONLY ONE INDEX IS CALLED ONE-DIMENSIONAL
ARRAYS.
• EXAMPLE
• #include <stdio.h>
int main() {
// Declare an integer array named 'numbers'
with a size of 5
int numbers[5] = {10, 20, 30, 40, 50};
// Access and print the elements of the
array
printf("The first element is: %dn",
numbers[0]); // Accessing the element at
index 0
printf("The second element is: %dn",
numbers[1]); // Accessing the element at
index 1
printf("The third element is: %dn",
numbers[2]); // Accessing the element at
index 2
printf("The fourth element is: %dn",
numbers[3]); // Accessing the element at
index 3
printf("The fifth element is: %dn",
numbers[4]); // Accessing the element at
index 4
return 0;
• A VARIABLE WHICH
REPRESENT THE LIST OF ITEMS
USING TWO INDEX IS CALLED
TWO DIMENSIONAL ARRAY
• EXAMPLE
• int matrix[2][3] = { //
Declares a 2x3 array (2
rows, 3 columns)
{1, 2, 3}, // First row
{4, 5, 6} // Second row
};
• DECLARATION OF TWO
DIMENSIONAL ARRAY.
• IN C++
• YOU DECLARE A 2D ARRAY
LIKE THIS
• //Declaring a 2d array
• Int array[3][3] ={{1,2,3},
• {4,5,6},
• {7,8,9}};
• DECLARATION OF ONE
DIMENSIONAL ARRAY.
• IN C++
• YOU DECLARE A 1D ARRAY
LIKE THIS.
• //declaring a 1d array
• int array[ ]={1,2,3,4,5,};
• INITILIALIZATION OF ONE-
DIMENSIONAL ARRAYS:
• IN C++,YOU CAN INITIALIZE
A 1-D ARRAY LIKE THIS
• // Initializing a 1D array
• Int array[]={10,20,30,40,50};
• OR USING THE SIZE:
• Int
array[5]={10,20,30,40,50};
• INITIALIZATION OF TWO
DIMENSIONAL ARRAYS:
• IN C++,YOU CAN INITIALIZE A
2-D ARRAY LIKE THIS
• //Initializing a 2D array
• Int array[3][3]={
• {10,20,30},
• {40,50,50},
• {70,80,90}
• };
COMPILE TIME INITIALIZATION OF 1D ARRAYS COMPILE TIME INITIALIZATION OF 2D
ARRAYS
• Compile-time initialization
of a 2D array in C++ means
initializing the array with
values at the time the
program is compiled. Just
like a 1D array, a 2D array's
size and elements are
specified during
compilation, and no
dynamic memory allocation
happens at runtime.
• Compile-time initialization
of a one-dimensional array
refers to initializing the
array when the program is
compiled, rather than
dynamically at runtime. The
array values are provided at
the point of declaration, and
the size of the array is
known during compilation.
•
#include <iostream>
• int main() {
• // Compile-time initialization of a 1D
array
• int array[] = {10, 20, 30, 40, 50}; // Size
is inferred automatically
• // Print the array elements
• for (int i = 0; i < 5; i++) {
• std::cout << array[i] << " ";
• }
• return 0;
• }
#include <iostream>
int main() {
// Compile-time initialization of a 2D array
int array[3][3] = {
{10, 20, 30},
{40, 50, 60},
{70, 80, 90}
};
// Print the array elements
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
COMPILE TIME INITIALIZATION OF 1D ARRAYS COMPILE TIME INITIALIZATION OF 2D
ARRAYS
• EXPLAINATION;
• 1.Arrays declaration and
initialization
• int array[]={10,20,30,40,50};
• int array[]:this declared a one-
dimensional array of integers.
• The size of the array is not
explicitly specified here.Instead,its
automatically inferred from the
number of elements inside the
curly braces {}.
std::cout << array[i][j] << " ";
}
std::cout << std::endl;
}
return 0;
}
EXPLAINATION:
1.ARRAY DECLARATION AND
INITIALIZATION.
• In this case,since there are 5
elements (10,20,30,40,50),the
compiler automatically
determines the array sieze to be
5.
• Compile time initialization means
that the values(10,20,30,40,50)
are known and assigned at the
point of declaration,so the array
is initialized with these values as
soon as the program is compiled.
int array[3][3] = {
{10, 20, 30},
{40, 50, 60},
{70, 80, 90}
};
int array[3][3]:this declaresa 2D array
of integers with 3 rows and 3
columns.
The size of the array([3][3]) is
explicitly specified, meaning the
array will hold 3 rows and 3 columns.
. .
• 2.PRINTING THE ARRAY ELEMENTS:
• For (int i = 0; i < 5; i++) {
• std::cout << array[i] << “ “;
• }
• A for loop is used to iterate through each
element of the array.
• Array[i] accesses each element of the
array,starting from array[0]
• (Which is 10).
• The loop runs from i=0 to i < 5, meaning it
will print all 5 elements.
• std::cout is used to output the array
elements to the console ,and “ “ is added
to print a space between the elements.
• Inside the curly braces {},you are initializing the
2D arrays with values:
• Row 1-{10,20,30}
• Row 2-{40,50,60}
• Row 3-{70,80,90}
• These values are assigned to the array at
compile time, so they are part of the compiled
program
• 2. Accessing and Printing the Array Elements:
• for (int i = 0; i < 3; i++) {
• for (int j = 0; j < 3; j++) {
• std::cout << array[i][j] << " ";
• }
• std::cout << std::endl;
• }
• 3.RETURN STATEMENT
• return 0;
• This marks the end of the
main() function and indicates
that the program has
executed successfully.
• OUTPUT;
• When you run this code, the
output will be
• 10 20 30 40 50
• This nested for loop is used to access and
print each element in the 2D array.
• The outer loop iterates through the rows (i
runs from 0 to 2).
• The inner loop iterates through the
columns(j runs from 0 to 2).
• array[i][j] accesses each element in the 2D
array
• std cout:: is used to print each element,and
std::end1 is used to move to the next line
after each row is printed.
• 3.OUTPUT
• 10 20 30
• 40 50 60
• 70 80 90
RUN TIME INITIALIZATION OF 1D ARRAYS RUN TIME INITIALIZATION
OF 2D ARRAYS
• Runtime initialization of a
1D array can be done using
dynamic memory allocation
or by initializing an array
after it is declared.
You can also initialize a 2D
array dynamically at
runtime using pointers and
dynamic memory allocation.
• Using Dynamic Memory
Allocation (for a 2D array):
• #include <iostream>
• int main() {
• // Runtime initialization of a 1D array using dynamic
memory allocation
• int size = 5; // Size of the array
• int* array = new int[size]; // Dynamically allocate
memory for a 1D array of integers
• // Initialize the array elements at runtime
• for (int i = 0; i < size; i++) {
• array[i] = (i + 1) * 10; // Assign values to array
elements
• }
• // Print the array elements
• for (int i = 0; i < size; i++) {
• std::cout << array[i] << " ";
• #include <iostream>
• int main() {
• // Runtime initialization of a 2D array using
dynamic memory allocation
• int rows = 3; // Number of rows
• int cols = 3; // Number of columns
• // Dynamically allocate memory for the 2D array
(rows x cols)
• int** array = new int*[rows]; // Allocate memory
for rows
• for (int i = 0; i < rows; i++) {
• array[i] = new int[cols]; // Allocate memory for
columns in each row
• }
• }
• std::cout << std::endl;
• // Free the dynamically
allocated memory
• delete[] array;
• return 0;
• }
• // Initialize the array elements at runtime
• int value = 10;
• for (int i = 0; i < rows; i++) {
• for (int j = 0; j < cols; j++) {
• array[i][j] = value; // Assign values to
the array elements
• value += 10;
• }
• }
• // Print the array elements
• for (int i = 0; i < rows; i++) {
• for (int j = 0; j < cols; j++) {
• std::cout << array[i][j] << " ";
• }
• std::cout << std::endl;
• }
• // Free the dynamically allocated memory
• for (int i = 0; i < rows; i++) {
• delete[] array[i]; // Deallocate memory
for each row
• }
• delete[] array; // Deallocate memory for
the array of rows
• return 0;
• EXPLAINATION:
• Dynamic Allocation: The array is
dynamically allocated with new
int[size] where runtime is
determined at runtime (in this case
5.
• Runtime Initialization: Values are
assigned to the array elements
inside the for loop at runtime.
• Memory Deallocation: After using
the array, the memory is
deallocated using delete[] to avoid
memory leak.
• EXPLAINATION:
• Dynamic Memory Allocation: A 2D array
is created dynamically using a pointer
to a pointer(int array**). Memory for
rows is allocated first new (int*[rows]),
and for each row, memory for the
columns is allocated ([new int[cols])
• Runtime Initialization: The array
elements are initialized with values
inside the nested for loops.
• Memory Deallocation: The dynamically
allocated memory is freed using
delete[] for each row and the entire
array.
MULTIDIMENSIONAL ARRAYS
•A multidimensional array is essentially an
array of arrays. It can have two or more
dimensions, and it is often used to represent
data structures like matrices, grids, or
tables. In most programming languages,
multidimensional arrays are represented
using a simple array notation, but internally,
they consist of arrays within arrays.

Yash Bhargava Array In programming in C

  • 1.
    NAME:YASH BHARGAVA CLASS:IT SEC: “G” ROLLNO.:06615603124 SUBJECT : PROGRAMMING IN C
  • 2.
    ARRAYS WHAT IS ANARRAY? -In programming, an array is a data structure that stores a collection of elements of the same data type in contiguous memory locations, allowing access to each element using an index. -It holds a collection of elements, all of which must be of the same data type (e.g., integers, strings, booleans). -The elements are stored in consecutive memory locations, meaning they are placed one after another in memory.
  • 3.
    SYNTAX FOR DECLARINGAND INITIALIZING AN ARRAY • Data_type name[size]; • Data_type name[size]={x,y,z,….};//size not required in this case! • Data_type name[rows][columns]; //for 2-d arrays • We can also initialize the array one by one by accessing it using the index. • Name[0]=0
  • 4.
    PROPERTIES OF ARRAY •DATA IN AN ARRAY IS STORED IN CONTIGUOUS MEMORY LOCATIONS. • EACH ELEMENT OF AN ARRAY IS OF SAME SIZE. • ANY ELEMENT OF THE ARRAY WITH GIVEN INDEX CAN BE ACCESSED VERY QUICKLY BY USING ITS ADDRESS WHICH CAN BE CALCULATED USING THE BASE ADDRESS AND THE INDEX.
  • 5.
    ADVANTAGES OF ANARRAY • IT IS USED TO REPRESENT MULTIPLE DATA ITEMS OF SAME TYPE BY USING ONLY SINGLE NAME. • ACCESSING AN ITEM IN A GIVEN ARRAY IS VERY FAST • 2 DIMENSIONAL ARRAYS MAKE IT EASY IN MATHEMATICAL APLICATIONS AS IT IS USED TO REPRESENT A MATRIX.
  • 6.
    DISADVANTAGES OF ANARRAY • POOR TIME COMPLEXITY OF INSERTION AND DELETION OPERATION. • WASTAGE OF MEMORY SINCE ARRAYS ARE FIXED IN SIZE. • IF THERE IS ENOUGH SPACE PRESENT IN THE MEMORY BUT NOT IN CONTIGUOUS FORM, YOU WILL NOT BE ABLE TO INITIALIZE ARRAY. • IT IS NOT POSSIBLE TO INCREASE THE SIZE OF THE ARRAY, ONCE YOU HAVE DECLAREDTHE ARRAY.
  • 7.
    TYPES OF ARRAYS: •1.ONEDIMENSIONAL ARRAYS. •2.TWO-DIMENSIONAL ARRAYS. •3.MULTIDIMENSIONAL ARRAYS.
  • 8.
    ONE DIMENSIONAL ARRAYSTWO DIMENSIONAL ARRAYS • A VARIABLE WHICHREPRESENT THE LIST OF ITEMS USING ONLY ONE INDEX IS CALLED ONE-DIMENSIONAL ARRAYS. • EXAMPLE • #include <stdio.h> int main() { // Declare an integer array named 'numbers' with a size of 5 int numbers[5] = {10, 20, 30, 40, 50}; // Access and print the elements of the array printf("The first element is: %dn", numbers[0]); // Accessing the element at index 0 printf("The second element is: %dn", numbers[1]); // Accessing the element at index 1 printf("The third element is: %dn", numbers[2]); // Accessing the element at index 2 printf("The fourth element is: %dn", numbers[3]); // Accessing the element at index 3 printf("The fifth element is: %dn", numbers[4]); // Accessing the element at index 4 return 0; • A VARIABLE WHICH REPRESENT THE LIST OF ITEMS USING TWO INDEX IS CALLED TWO DIMENSIONAL ARRAY • EXAMPLE • int matrix[2][3] = { // Declares a 2x3 array (2 rows, 3 columns) {1, 2, 3}, // First row {4, 5, 6} // Second row };
  • 9.
    • DECLARATION OFTWO DIMENSIONAL ARRAY. • IN C++ • YOU DECLARE A 2D ARRAY LIKE THIS • //Declaring a 2d array • Int array[3][3] ={{1,2,3}, • {4,5,6}, • {7,8,9}}; • DECLARATION OF ONE DIMENSIONAL ARRAY. • IN C++ • YOU DECLARE A 1D ARRAY LIKE THIS. • //declaring a 1d array • int array[ ]={1,2,3,4,5,};
  • 10.
    • INITILIALIZATION OFONE- DIMENSIONAL ARRAYS: • IN C++,YOU CAN INITIALIZE A 1-D ARRAY LIKE THIS • // Initializing a 1D array • Int array[]={10,20,30,40,50}; • OR USING THE SIZE: • Int array[5]={10,20,30,40,50}; • INITIALIZATION OF TWO DIMENSIONAL ARRAYS: • IN C++,YOU CAN INITIALIZE A 2-D ARRAY LIKE THIS • //Initializing a 2D array • Int array[3][3]={ • {10,20,30}, • {40,50,50}, • {70,80,90} • };
  • 11.
    COMPILE TIME INITIALIZATIONOF 1D ARRAYS COMPILE TIME INITIALIZATION OF 2D ARRAYS • Compile-time initialization of a 2D array in C++ means initializing the array with values at the time the program is compiled. Just like a 1D array, a 2D array's size and elements are specified during compilation, and no dynamic memory allocation happens at runtime. • Compile-time initialization of a one-dimensional array refers to initializing the array when the program is compiled, rather than dynamically at runtime. The array values are provided at the point of declaration, and the size of the array is known during compilation.
  • 12.
    • #include <iostream> • intmain() { • // Compile-time initialization of a 1D array • int array[] = {10, 20, 30, 40, 50}; // Size is inferred automatically • // Print the array elements • for (int i = 0; i < 5; i++) { • std::cout << array[i] << " "; • } • return 0; • } #include <iostream> int main() { // Compile-time initialization of a 2D array int array[3][3] = { {10, 20, 30}, {40, 50, 60}, {70, 80, 90} }; // Print the array elements for (int i = 0; i < 3; i++) { for (int j = 0; j < 3; j++) {
  • 13.
    COMPILE TIME INITIALIZATIONOF 1D ARRAYS COMPILE TIME INITIALIZATION OF 2D ARRAYS • EXPLAINATION; • 1.Arrays declaration and initialization • int array[]={10,20,30,40,50}; • int array[]:this declared a one- dimensional array of integers. • The size of the array is not explicitly specified here.Instead,its automatically inferred from the number of elements inside the curly braces {}. std::cout << array[i][j] << " "; } std::cout << std::endl; } return 0; } EXPLAINATION: 1.ARRAY DECLARATION AND INITIALIZATION.
  • 14.
    • In thiscase,since there are 5 elements (10,20,30,40,50),the compiler automatically determines the array sieze to be 5. • Compile time initialization means that the values(10,20,30,40,50) are known and assigned at the point of declaration,so the array is initialized with these values as soon as the program is compiled. int array[3][3] = { {10, 20, 30}, {40, 50, 60}, {70, 80, 90} }; int array[3][3]:this declaresa 2D array of integers with 3 rows and 3 columns. The size of the array([3][3]) is explicitly specified, meaning the array will hold 3 rows and 3 columns. . .
  • 15.
    • 2.PRINTING THEARRAY ELEMENTS: • For (int i = 0; i < 5; i++) { • std::cout << array[i] << “ “; • } • A for loop is used to iterate through each element of the array. • Array[i] accesses each element of the array,starting from array[0] • (Which is 10). • The loop runs from i=0 to i < 5, meaning it will print all 5 elements. • std::cout is used to output the array elements to the console ,and “ “ is added to print a space between the elements. • Inside the curly braces {},you are initializing the 2D arrays with values: • Row 1-{10,20,30} • Row 2-{40,50,60} • Row 3-{70,80,90} • These values are assigned to the array at compile time, so they are part of the compiled program • 2. Accessing and Printing the Array Elements: • for (int i = 0; i < 3; i++) { • for (int j = 0; j < 3; j++) { • std::cout << array[i][j] << " "; • } • std::cout << std::endl; • }
  • 16.
    • 3.RETURN STATEMENT •return 0; • This marks the end of the main() function and indicates that the program has executed successfully. • OUTPUT; • When you run this code, the output will be • 10 20 30 40 50 • This nested for loop is used to access and print each element in the 2D array. • The outer loop iterates through the rows (i runs from 0 to 2). • The inner loop iterates through the columns(j runs from 0 to 2). • array[i][j] accesses each element in the 2D array • std cout:: is used to print each element,and std::end1 is used to move to the next line after each row is printed. • 3.OUTPUT • 10 20 30 • 40 50 60 • 70 80 90
  • 17.
    RUN TIME INITIALIZATIONOF 1D ARRAYS RUN TIME INITIALIZATION OF 2D ARRAYS • Runtime initialization of a 1D array can be done using dynamic memory allocation or by initializing an array after it is declared. You can also initialize a 2D array dynamically at runtime using pointers and dynamic memory allocation. • Using Dynamic Memory Allocation (for a 2D array):
  • 18.
    • #include <iostream> •int main() { • // Runtime initialization of a 1D array using dynamic memory allocation • int size = 5; // Size of the array • int* array = new int[size]; // Dynamically allocate memory for a 1D array of integers • // Initialize the array elements at runtime • for (int i = 0; i < size; i++) { • array[i] = (i + 1) * 10; // Assign values to array elements • } • // Print the array elements • for (int i = 0; i < size; i++) { • std::cout << array[i] << " "; • #include <iostream> • int main() { • // Runtime initialization of a 2D array using dynamic memory allocation • int rows = 3; // Number of rows • int cols = 3; // Number of columns • // Dynamically allocate memory for the 2D array (rows x cols) • int** array = new int*[rows]; // Allocate memory for rows • for (int i = 0; i < rows; i++) { • array[i] = new int[cols]; // Allocate memory for columns in each row • }
  • 19.
    • } • std::cout<< std::endl; • // Free the dynamically allocated memory • delete[] array; • return 0; • } • // Initialize the array elements at runtime • int value = 10; • for (int i = 0; i < rows; i++) { • for (int j = 0; j < cols; j++) { • array[i][j] = value; // Assign values to the array elements • value += 10; • } • } • // Print the array elements • for (int i = 0; i < rows; i++) { • for (int j = 0; j < cols; j++) { • std::cout << array[i][j] << " ";
  • 20.
    • } • std::cout<< std::endl; • } • // Free the dynamically allocated memory • for (int i = 0; i < rows; i++) { • delete[] array[i]; // Deallocate memory for each row • } • delete[] array; // Deallocate memory for the array of rows • return 0;
  • 21.
    • EXPLAINATION: • DynamicAllocation: The array is dynamically allocated with new int[size] where runtime is determined at runtime (in this case 5. • Runtime Initialization: Values are assigned to the array elements inside the for loop at runtime. • Memory Deallocation: After using the array, the memory is deallocated using delete[] to avoid memory leak. • EXPLAINATION: • Dynamic Memory Allocation: A 2D array is created dynamically using a pointer to a pointer(int array**). Memory for rows is allocated first new (int*[rows]), and for each row, memory for the columns is allocated ([new int[cols]) • Runtime Initialization: The array elements are initialized with values inside the nested for loops. • Memory Deallocation: The dynamically allocated memory is freed using delete[] for each row and the entire array.
  • 22.
    MULTIDIMENSIONAL ARRAYS •A multidimensionalarray is essentially an array of arrays. It can have two or more dimensions, and it is often used to represent data structures like matrices, grids, or tables. In most programming languages, multidimensional arrays are represented using a simple array notation, but internally, they consist of arrays within arrays.