Showing posts with label introduction to array in C. Show all posts
Showing posts with label introduction to array in C. Show all posts

Tuesday, March 5, 2024

INTRODUCTION TO ARRAY IN C LANGUAGE

INTRODUCTION TO ARRAY


  • ADVANTAGE AND DISADVANTAGE
  • DECLARATION OF ARRAY
  • INITIALIZATION OF ARRAY
  • 2-D ARRAY/INITIALIZATION
  • PASSING ARRAY TO A FUNCTION 
A collection of identically typed data pieces kept in adjacent memory locations is called an array. Arrays are derived data types in C that are used to store primitive data types like int, char, double, float, etc. In addition, it may store a variety of derived data types, including pointers and structures. The simplest data structure is an array since each data component may be accessed at random by using its index number.

The C array comes in handy when you need to hold related elements. For instance, we don't need to construct separate variables for the marks in each topic if we need to keep a student's marks across six subjects. Alternatively, we can create an array that can store the marks for every subject at consecutive memory locations.

We can easily access the elements by utilizing the array. To access the items of the array, a few lines of code are all that are needed.

Array has some properties also let’s understand them

·       Each entry in the array, for instance, int = 4 bytes, has the same size and data type.

·       Array elements are stored in memory locations, with the first member being stored in the smallest position.

·       Since we can find the addresses of array items using a specified base address and data element size, you can use the array items at random.

 Advantage

1. Code Optimization: Use less code to access data more effectively.

2. A for loop may be used to rapidly and easily obtain array elements, which makes traversal a joy.

3. Simple sorting: A few lines of code are all that are needed to sort the elements in an array.

4. We can randomly access any element in an array.

Disadvantage

Fixed-size: Whatever size we specify while defining the table, we cannot exceed the limit. So it doesn't grow dynamically like LinkedList, which we'll learn about later.

 Declaration of array in c

we can declare the array like

Initialization of array

The basic method to initialize or identify the element is indexing. We can initialize each index to a particular element.

Suppose:

As we had seen above marks are the name of the array and the size of the array is 5 then:

Marks0 = 70; (initializing point)

Marks1 = 60;

Marks2 = 80;

Marks3 = 55;

Marks4 = 40;

70

60

80

55

40

 

Marks0

Marks1

Marks2

Marks3

Marks4

 

Let us understand this by a program

#include<stdio.h>  

int main(){   


Array declaration with initialization

 

Additionally, we may set the array's size at declaration time. Let's see how

int marks [5]={20,40,60,80,30}

In these circumstances, we can also initialize the value straight away without specifying the array's size.

int marks []={20,40,60,80,30}

Let us understand this a C program 

 



 

Let us understand some basic simple programs in C having arrays

 

We are now doing sorting of an array having bubble sort method to sort the array in ascending order

 


Try to have this program and comment your output.

Now we will try to print the largest as well as second largest element in the array

 


Try to have this program and comment on your output.

 

2-D (two dimensional) Array

 

A two-dimensional array can be defined as a collection of arrays. A matrix is really just a collection of rows and columns, and that is how a 2D table is organized. To create a data structure that is akin to a relational database, 2D tables are created. It makes managing enormous volumes of data at once easier and can be supplied to other activities as needed.

 

Let’s understand the syntax first

Data_type array_name[rows][columns]

Example

Int marks[2][4];

Here int shows the data type

Marks shows the name of the array

2 show the number of rows

4 shows the number of columns

 

Initialization of 2-D Array

 

When declaring and initializing a 1D array simultaneously, sizing is unnecessary. On the other hand, 2D arrays will not be able to use this. The second dimension of the array needs to be specified. An illustration of declaring and defining a two-dimensional array is provided here:

 

Let us understand this by an example

Int arr[4][3]={{1,2,3},{4,5,6},{7,8,9},{6,4,5}};

 

Let us understand this by a program

 

through



let us try to store elements in a matrix and print it




 Return an array in C

 

let us understand how to pass an array in a function

 The getarray() function is used in the preceding code snippet with an array of recently generated elements, arr[]. Basically, the getarray() method prints each element of the array arr[].

 Output

Elements of an array are 45 67 78 90 

Passing an array to a function

Let us understand the program



In the code above, we passed an array as a pointer to the function. The printarray() function prints the elements of an array.

Output

Elements of an array are A, B, C, D, E

 Returning pointer pointing to the array



  

In the program above, the function getarray() returns the variable arr.

Although a local variable is assigned a value, the memory space was illegally allocated by the stack function. All variables are removed from the stack when main() is called again. Given that this software replaces a deleted region in memory, it is safe to say that it creates a segmentation fault.



Array outside function (segmentation fault )

There are three ways of returning arrays to a function

  • Using dynamically allocated array
  • Using a static array
  • Using structure

Let us figure out all three by a C program 

Returning array by passing an array which is to be returned as a parameter to the function.




Using static variable





Using Structure

Because structures are user-defined data types, they can include collections of different kinds of objects. The next stage is to build code that, when it runs, will produce an array using structure.

 






CONDITIONAL STRUCTURE IN C LANGUAGE

Conditional structure in c

SIMPLE IF STATEMENT (FLOWCHARTS)
IF-ELSE STATEMENTS (FLOWCHARTS)
NESTED IF-ELSE STATEMENTS (FLOWCHARTS)
ELSE-IF LADDER (FLOWCHARTS)

If you are a programmer, you are already familiar with (if...else) statements. Therefore, you must educate yourself! Beginners need to understand (if...else) expressions. Upon completion of this blog, By the end of this lesson, you will be able to use if-then statements with basic C programming knowledge.

Conditional statement in c

The primary types of control statements in C are:

·       Decision-making control statements
1. Simple if statement
2. If-else statements
3. Nested if-else statements
4. else-if ladder

·       Conditional statements 

·       Goto statements in C

·       Loop control statements in C
1. While Loop
2. Do-while Loop
3. For Loop

 

      1)     Simple-if statement

 If a condition is true, an action may be performed using simple if statements. The statements outside the if block take control if the condition of the if statement is false, and the sentences inside the if block execute if the condition is true.

Here is the syntax for the if statement:

If (condition)

{

Statement;

}


Flowchart

 



 Let us understand this by a program




2)     If-else statement

 

If a condition is satisfied, the code can be executed using the if-else expression. Based on the situation, the code will execute either the if block or the else block.

 The if-else statement has the following syntax:

 If(condition)

Statement 1;

Else

Statement 2;

 

 Flowchart

 







 3)     Nested if-else statements

Inside the nested if-else lines, you'll find another if or else. Therefore, the condition of the "if" block (an outer if) must be true for the if block that includes an inner if to be performed. If the condition of the if block is true, then the statements within the if block are run; if not, the statements within the inner if's "else" block are executed.

Whenever the outer "if" condition is not true, the "else" block of the outer if, which is also an if, is performed. Depending on the condition, the statement within the outer else's inner if is performed if true; otherwise, the else block is executed

 The nested if-else statement has the following syntax:

 If (condition)

{

// if a block of outer if’s

If (condition2)

{

statement 1;

}

Else

{

Statement 2;

}

}

 

// else block of outer if’s

Else

{

If(condition3)

{

Statement 3;                  //inner if

}

Else

{

Statement 4;                //else block of inner if

}

}

 

Flowchart

 



 

    4)     Else if the ladder statement

 

The statements under each "if" in the else-if ladder are executed if one of the two conditions is true; if not, the statements under the else block are executed. The else-if ladder contains a large number of else-if statements.

 

All statements are executed based on the "if" condition. If one of the "if" conditions is false, then the other "if" condition is checked. If that one is true as well, then the statements based on that particular "if" condition are executed. This process will run indefinitely provided the else-if lines are there in the code.

 

The else-if ladder statement has the following syntax:

 

if (condition 1)

{

Statement 1;

}

else if (condition2)

{

Statement 2;

}

else lf (condition3)

{

Statement 3;

}

……………….

 

else if (condition n-l)

{

statement n-l;

}

Else

{

statement n;

} 

 Let us better understand this by an example: -

 

 

     5) Conditional control statements

Multi-way branching will be permitted by the switch statement depending on the expression's value for the switch.

 

Control is sent to that specific case label and the statements under it are executed based on the expression. If the switch expression doesn't fit any of the conditions, the default statement is performed.

 The switch statement has the following:

 

Switch (expression)

{

Case label 1: statement 1;

break;

Case label 2: statement 2;

break;

Case label 3: statement 3;

break;

Case label n: statement;

break;

default: default statement;

}

Other statements;

 

Flowchart

 


Let us understand this by a program in C: -

 

 

6) Got to statement in c

 A jump control statement, which is another term for the goto statement, is a program statement that directs the user to a certain area. Programs can alter the control flow by using goto instructions. Labels are names that direct the goto statement's branch to a particular position in the program.

Go to statement syntax is as follows: -

Syntax: got to label name;

Example: goto odd;

 

6.1) while loop

 

A while loop is sometimes called an entrance loop because the lines that make up its body are executed once the condition is fulfilled.

For the first time, if the while loop condition is false, the statements within will not be executed.

After this, you will find the while loop syntax: -

While(condition)

{

Statement 1 ;

Statement 2;

Statement n;

} 

 


 Let us better understand this by a program


6.2) do-while loop

 Another name for a do-while loop is an exit loop since it checks the condition second after executing the statements.

For every true condition in the while loop, the body will continue to execute until it becomes false. If the condition is not true, the control will exit the while loop and run the subsequent statements.

The syntax of do-while is as follows: -

Do

{

Statement 1;

Statement 2;

…………………

…………………

}


flowchart

 

6.3) for loop

 Pre-test loop is another name for the for loop. Expression 1 is an initialization, Expression 2 is a conditional expression, and Expression 3 is an update, according to the grammar. Initializing the variables for the statement can be done.

 

The syntax is given below: -

 

For(expression 1;expression 2;expression 3)

{

Statement 1;

Statement 2;

……………

……………

}

Statement n;

 

Within the for loop, Expression1 is used to set the value of the variable. Expression 2 is then looked at to see whether the condition is true. The lines under Expression 3 are performed after the loop's body if the for-loop is executed. If the for loop's condition is true, the process will continue; if not, it will carry out the statements that follow the for loop. 

Flowchart






Featured Post

ASSOCIATION RULE IN MACHINE LEARNING/PYTHON/ARTIFICIAL INTELLIGENCE

Association rule   Rule Evaluation Metrics Applications of Association Rule Learning Advantages of Association Rule Mining Disadvantages of ...

Popular