KEMBAR78
C Language UNIT-3 C NOTES | PDF | String (Computer Science) | Integer (Computer Science)
0% found this document useful (0 votes)
35 views18 pages

C Language UNIT-3 C NOTES

The document provides an overview of arrays in programming, including their definition, declaration, and operations such as accessing, storing, and manipulating elements in one-dimensional, two-dimensional, and multi-dimensional arrays. It also covers methods for initializing arrays, inputting values, and performing operations like traversal, insertion, deletion, merging, and searching. Additionally, it discusses character handling and strings, along with examples and syntax for practical implementation.

Uploaded by

sainaagin123
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
35 views18 pages

C Language UNIT-3 C NOTES

The document provides an overview of arrays in programming, including their definition, declaration, and operations such as accessing, storing, and manipulating elements in one-dimensional, two-dimensional, and multi-dimensional arrays. It also covers methods for initializing arrays, inputting values, and performing operations like traversal, insertion, deletion, merging, and searching. Additionally, it discusses character handling and strings, along with examples and syntax for practical implementation.

Uploaded by

sainaagin123
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 18

St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc.

, II Semester

Unit – III
UNIT III
Arrays: Introduction – Declaration of Arrays – Accessing elements of the Array – Storing Values in Array–
Operations on Arrays – one dimensional, two dimensional and multi-dimensional arrays, character handling
and strings.

Arrays
➔ Definition of an array: -
Array is a Data Structure. Array is a variable. Array is a collection of similar data elements
(Homogenous elements, which are having same data types) stored in adjacent memory locations sharing a
common name.

Array is represented by a variable called subscripted variable. The variable is always represented by its
subscript which is the index number of the element. Every element in an array is identified by the index. The
index starts from 0. Hence the index of first element is 0 and last element is (size – 1).

The elements of array are always stored in contiguous memory locations. Hence it is sequential data
structure.

Declaration of an array: -

Before using an array, its type and size must be declared. An array is declared in the following
way.

Syntax:

Data type array_name[size_of_array];

Example:

int a[10]; a is the name of the array, can hold 10 integer values.

float b[5]; b is the name of the array, can hold 5 floating point numbers.

char c[30]; c is the name of the array, can hold 30 characters.

The C never checks the validity of the array index-neither at compilation time nor at run time. Even if you
declare an array of 10 elements and later on by mistake try to access the 11 th element, no error will be
generated. But the result will be unpredictable as the memory occupied by the 11th element may be storing
data of another object.

➔ Accessing elements of the array:


For accessing an individual element of the array, the array subscription or index is used.

Department of Computer Science Page 1


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

For ex: arr[0] - to access the first element of the array.

To access all the elements of the array we need to use loop.

For ex: To initialize -1 in each element of the array. We use one for loop

int i, a[10];
for(i=0;i<10;i++)
a[i] = -1;
To read, access or print all the elements of the array, we need to use for/while/do-while loop to execute the
same statement with different index values. Array name is the symbolic reference to the first byte of the
array. When we use the array name we are referring to the first byte of the array i.e base address of the
array

➔ Storing values in the array:


Declaring an array is just allocating space for the elements, no values are stored in the array. To store
values in the array , there are 3 ways to do

1. Initialize the elements.


2. Input values for the elements.
3. Assign values to the elements.
Initialization of an array:-

An array can be initialized at the time of declaration. Here the array size specification is optional.

Syntax: datatype array_ name[size]={list of values};


Department of Computer Science Page 2
St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

Example:

1. int arr[5] = {10, 20, 30, 40, 50};

2. float b[ ] = {10.5, 1.3, 2.5};

The array elements are initialized to garbage values by default. The size of array should be always an integer
greater than 0.

Eg:- int a[-10], b[0], c[2.5] are all invalid declarations

Note: if we have more initializers than the declared size of the array, then a complier time error will be
generated. For example, the following statement will result in a compiler error.

int marks[3]={1,2,3,4};

Inputting Values:
In this method a while/do-while/for loop is executed to input the value for each element of the array.

For ex:

int i, a[10];
for(i=0;i<10;i++)
scanf(“%d”, &a[i]);

Assigning Values:
A simple assignment statement can be written as

marks[3]=100; here 100 is assigned to the fourth element of the array marks.

Storing values in an array:

#include<stdio.h>
int main()
{
int values[5];
printf(“Enter 5 integers”);
Department of Computer Science Page 3
St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

for(i=0;i<5;i++)
{
scanf(“%d”,&values[i]);
}
printf(“Displaying integer values”);
for(int i=0;i<5;i++)
{
printf(“%d\t”,values[i]);
}
return 0;
}
OUTPUT:

Enter 5 integers
10
20
30
40
50
Displaying integer values
10 20 30 40 50

➔ Operations on Arrays:
There are number of operations that can be performed on arrays. Some operations are as follows:

➢ Traversal

➢ Insertion

➢ Deletion

➢ Merging

➢ Searching.

Traversal: Traversing the array element means accessing each and every element of the array for a specific
purpose. For example, “arr” is an array of similar data elements, then traversing the data elements can
include printing every element, counting the total number of elements etc.

Insertion: Inserting an element in the array means adding a new data element in an already existing array.
For example, if an array is declare to contain 10 elements, but currently it is having only 8 elements, then
there is space to accommodate two more elements.

Department of Computer Science Page 4


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

Deletion: Deleting an element from the array means removing a data element from an already existing array.

Merging: Merging two arrays in a third array means first copying the contents of the first array into the third
array and then copying the contents of the second array into the third array. Hence, the merged array
contains the contents of the first array followed by contents of the second array.

Searching: 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 gives the location of
that value in the array. Otherwise, if the value is not present in the array, then the searching is said to be
unsuccessful. There are two popular methods for searching the array elements, one is “Linear search” and
the second is “Binary Search”.

➔ Types of Arrays:-
There are three types of arrays. They are

• Single dimensional array


• Two dimensional array
• Multi dimensional array

✓ Single dimensional array:


An array with only single subscripted value is called a single dimensional array.

int a[5];

'a' is a single dimensional array.

Eg:-

void main( )
{
int a[3] = {10, 20, 30};
int b[ ] = {100, 200, 300, 400, 500};
int i;
clrscr( );
printf("\n The elements of a :\n\n");
for(i=0;i<3;i++)
printf("%5d",a[i]);
printf("\n\n The elements of b :\n\n");
for(i=0;i<5;i++)
printf("%5d",b[i]);
getch( );
}
✓ Double or two dimensional array:
An array with two subscripted values is called a double dimensional array. A 2D array is a collection of
many 1D arrays.

Department of Computer Science Page 5


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

int a[5][3];

'a' is a double dimensional array.

In the above example 'a' is an array of 5 single dimensional arrays each of size 3.

Eg:-

/* Example on 2D Array declaration */

main( )
{
int a[2][3] = { {10,20,30}, {40,50,60} };
int b[3][2] = { 10,20,30,40,50,60 };
int c[2][2];
c[0][0] = 10; c[0][1] = 20;
c[1][0] = 30; c[1][1] = 40;
clrscr( );
printf("\n\n Elements of a :\n");
printf("\n%3d%3d%3d",a[0][0],a[0][1],a[0][2]);
printf("\n%3d%3d%3d",a[1][0],a[1][1],a[1][2]);
printf("\n\n Elements of b :\n");
printf("\n%3d%3d",b[0][0],b[0][1]);
printf("\n%3d%3d",b[1][0],b[1][1]);
printf("\n%3d%3d",b[2][0],b[2][1]);
printf("\n\n Elements of c :\n");
printf("\n%3d%3d",c[0][0],c[0][1]);
printf("\n%3d%3d",c[1][0],c[1][1]);
getch( );
}

Another method to read and write a 2D array

#include<stdio.h>
int main(){
/* 2D array declaration*/
int disp[2][3];
/*Counter variables for the loop*/
int i, j;
for(i=0; i<2; i++) {
for(j=0;j<3;j++) {
printf("Enter value for disp[%d][%d]:", i, j);
scanf("%d", &disp[i][j]);
}
}
//Displaying array elements
printf("Two Dimensional array elements:\n");
for(i=0; i<2; i++) {
for(j=0;j<3;j++) {
printf("%d ", disp[i][j]);
if(j==2){

Department of Computer Science Page 6


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

printf("\n");
}
}
}
return 0;
}
Output:

Enter value for disp[0][0]:1


Enter value for disp[0][1]:2
Enter value for disp[0][2]:3
Enter value for disp[1][0]:4
Enter value for disp[1][1]:5
Enter value for disp[1][2]:6
Two Dimensional array elements:
1 2 3
4 5 6

✓ Multidimensional arrays:
An array with multiple subscripted values is called a multi dimensional array.

int a[5][3][4];

In the above example a is a multidimensional array (3D array). 'a' is a collection of 5 2 Dimensional arrays
each of size 3x4.

[EXTRA CONTENT FOR ARRAYS]

➔ One dimensional arrays for Inter-function communication:


We know that we can pass the variables as parameters to a function. Similarly, we can also pass an
array to a function. There are two ways to pass an array to a function:

1) Passing individual elements.

2) Passing an entire array.

1) Passing individual elements: The individual elements of an array can be passed to a function either by
passing their addresses (or) their data valued.

Eg:

#include <stdio.h>
void display(int age1, int age2)
{
printf("%d\n", age1);
printf("%d\n", age2);
}

Department of Computer Science Page 7


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

int main()
{
int ageArray[] = {2, 8, 4, 12};

// Passing second and third elements to display()


display(ageArray[1], ageArray[2]);
return 0;
}

Output

2) Passing an entire array:

We know that the array name refers to the first byte of the array in memory. The address of rest of
the elements in the array can be calculated by using the array name and the index value of the element.
Therefore, we can pass an entire array to a function by simply passing the name of the array to a function.

#include<stdio.h>
#include<conio.h>
void main( )
{
int arr[5]={1,2,3,4,5};
func1(arr[3]);
func2(&arr[3]);
getch();
}
void func1(int num)
{
printf(“\n passing data value to a function”);
printf(”%d”,num);
}
void func2(int *num)
{
pritnf(“\n passing address to a function”);
printf(“\n %d”,num);
}
➔ Operations on two dimensional arrays:-
We can perform the following operations on a two dimensional array:
1. Transpose: Transpose of a mXn matrixA is given as a nXm matrixB where Bi, j = Aj, i

Department of Computer Science Page 8


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

2. Sum: Two matrices that are compatible with each other can be added together. 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
3. Difference: Two matrices that are compatible with each other can be subtracted. 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
4. 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, mXn matrixA can be
multiplied with pXq matrixB if n=p. Elements of the matrices can be multiplied by writing
Ci,j=∑Ai,k X Bk,j
➔ Sparse Matrices :
A matrix is a two-dimensional data object made of m rows and n columns, therefore having total
m x n values. If most of the elements of the matrix have 0 value, then it is called a sparse matrix.

#include <stdio.h>
void main( )
{
int array[10][10], i, j, m, n,counter = 0;
printf("Enter the order of the matix \n");
scanf("%d %d", &m, &n);
printf("Enter the elements of the matix \n");
for (i = 0; i < m; ++i)
{
for (j = 0; j < n; ++j)
{
scanf("%d", &array[i][j]);
if (array[i][j] == 0)
{
++counter;
}
}
}
printf(“The array is :\n”);
for (i = 0; i < m; ++i)
{
for (j = 0; j < n; ++j)
{
printf("%d\t", array[i][j]);
}
printf(“\n”);
}

if (counter > ((m * n) / 2))


{
printf("The given matrix is sparse matrix \n");
}
else

Department of Computer Science Page 9


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

printf("The given matrix is not a sparse matrix \n");


printf("There are %d number of zeros", counter);
}
Character Handling and Strings
Character handling functions:
Following are the functions defined in the header ctype.h −

Sr.No. Function & Description

1 int isalnum(int c)

This function checks whether the passed character is alphanumeric.

2 int isalpha(int c)

This function checks whether the passed character is alphabetic.

3 int iscntrl(int c)

This function checks whether the passed character is control character.

4 int isdigit(int c)

This function checks whether the passed character is decimal digit.

5 int isgraph(int c)

This function checks whether the passed character has graphical representation using
locale.

6 int islower(int c)

This function checks whether the passed character is lowercase letter.

7 int isprint(int c)

This function checks whether the passed character is printable.

8 int ispunct(int c)

This function checks whether the passed character is a punctuation character.

Department of Computer Science Page 10


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

9 int isspace(int c)

This function checks whether the passed character is white-space.

10 int isupper(int c)

This function checks whether the passed character is an uppercase letter.

11 int isxdigit(int c)

This function checks whether the passed character is a hexadecimal digit.

The library also contains two conversion functions that accepts and returns an "int".

Sr.No. Function & Description

1 int tolower(int c)

This function converts uppercase letters to lowercase.

2 int toupper(int c)

This function converts lowercase letters to uppercase.

Arithmetic operations on characters:

We can also manipulate the characters as we manipulate numbers in c language.

When ever the system encounters the character data it is automatically converted into a integer value by
the system.

We can represent a character as a integer by using the following method.

x=’a’;
printf(“%d\n”,x);

Will display 97 on the screen.

Arithmetic operations can also be performed on characters

For example

x=’z’-1; is a valid statement.

Department of Computer Science Page 11


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

The ASCII value of ‘z’ is 122 the statement and therefore will assign 121 to variable x.

It is also possible to use character constants in relational expressions.

For example

ch>’a’ && ch < = ’z’

it will check whether the character stored in variable “ch” is a lower-case letter.

String:-
A string is a sequence of characters. Any sequence or set of characters defined within double quotation
symbols is a constant string. In C it is required to do some meaningful operations on strings they are:

1. Finding the length of the string


2. Combining or concatenating strings
3. Copying one string to another.
4. Comparing string & checking whether they are equal
5. Reading and writing strings
Strings are stored in memory as ASCII codes of characters that make up the string appended with
‘\0’(ASCII value of null). Normally each character is stored in one byte, successive characters are stored in
successive bytes.The last character is the null character having ASCII value zero.

Initializing Strings:-

The initialization of a string must the following form which is simpler to one dimension array.

char month1[ ]={‘j’,’a’,’n’,’u’,’a’,’r’,’y’}; (or)

char month[]=”January”;

Then the string month is initializing to January. This is perfectly valid but C offers a special way to
initialize strings. The above string can be initialized char month1[]=”January”; The characters of the string
are enclosed within a part of double quotes. The compiler takes care of string enclosed within a pair of a
double quotes. The compiler takes care of storing the ASCII codes of characters of the string in the
memory and also stores the null terminator in the end.

/*String.c string variable*/


#include < stdio.h >
main()
{
char month[15];
printf (“Enter the string”);
gets (month);
printf (“The string entered is %s”, month);
}

Department of Computer Science Page 12


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

In this example string is stored in the character variable month the string is displayed in the statement.

printf(“The string entered is %s”, month”);

It is one dimension array. Each character occupies a byte. A null character (\0) that has the ASCII value
0 terminates the string. The figure shows the storage of string January in the memory recall that \0 specifies
a single character whose ASCII value is zero.

\0

Character string terminated by a null character ‘\0’.


A string variable is any valid C variable name & is always declared as an array. The general form of
declaration of a string variable is

char string_name[size];

The size determines the number of characters in the string name.

Example:

char month[10];
char address[100];

The size of the array should be one byte more than the actual space occupied by the string since the
complier appends a null character at the end of the string.

------------------------------------------------------------------------------------------------------------------------------------

➢ Reading Strings from the terminal:


The function scanf with %s format specification is needed to read the character string from the terminal.

Example:

Department of Computer Science Page 13


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

char address[15];
scanf(“%s”,address);

➢ Writing strings to screen:


The printf statement along with format specifier %s to print strings on to the screen. The format %s can
be used to display an array of characters that is terminated by the null character for example
printf(“%s”,name); can be used to display the entire contents of the array name.

------------------------------------------------------------------------------------------------------------------------------------

➢ String operations (string.h)


C language recognizes that string is a different class of array by letting us input and output the array as a
unit and are terminated by null character. C library supports a large number of string handling functions

• Length (number of characters in the string).


• Concatenation (adding two are more strings)
• Comparing two strings.
• Copy(copies one string over another)
To do all the operations described here it is essential to include string.h library header file in the
program.

1. strlen( ) function:

This function counts and returns the number of characters in a string. The length does not include a null
character.

Syntax

n=strlen(string);

Where n is integer variable. Which receives the value of length of the string.

Example

length=strlen(“Hollywood”);

The function will assign number of characters 9 in the string to an integer variable length.

Example:-

/*write a c program to find the length of the string using strlen() function*/
#include < stdio.h >
include < string.h >
void main( )
{

Department of Computer Science Page 14


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

char name[100];
int length;
printf(“Enter the string”);
gets(name);
length=strlen(name);
printf(“\nNumber of characters in the string is=%d”,length);
}

2. strcat( ) function:

when you combine two strings, you add the characters of one string to the end of other string. This
process is called concatenation. The strcat() function joins 2 strings together. It takes the following form

strcat(string1,string2);

string1 & string2 are character arrays. When the function strcat is executed string2 is appended to
string1. the string at string2 remains unchanged.

Example :-

strcpy(string1,”sri”);
strcpy(string2,”Bhagavan”);
printf(“%s”,strcat(string1,string2);

From the above program segment the value of string1 becomes sribhagavan. The string at str2 remains
unchanged as Bhagavan.

3. strcmp( ) function:

In c you cannot directly compare the value of 2 strings in a condition like if(string1==string2)
Most libraries however contain the strcmp() function, which returns a zero if 2 strings are equal, or a non
zero number if the strings are not the same. The syntax of strcmp() is given below:

strcmp(string1,string2)

String1 & string2 may be string variables or string constants. String1, & string2 may be string variables
or string constants some computers return a negative if the string1 is alphabetically less than the second
and a positive number if the string is greater than the second.

Example:-

strcmp(“Newyork”,”Newyork”) will return zero because 2 strings are equal.


strcmp(“their”,”there”) will return a 9 which is the numeric difference between ASCII ‘i’ and ASCII ’r’.
strcmp(“The”, “the”) will return 32 which is the numeric difference between ASCII “T” & ASCII “t”.

Department of Computer Science Page 15


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

4.strcpy( ) function:

C does not allow you to assign the characters to a string directly as in the statement name=”Robert”;
Instead use the strcpy(0 function found in most compilers the syntax of the function is illustrated below.

strcpy(string1,string2);

strcpy function assigns the contents of string2 to string1. string2 may be a character array variable
or a string constant.

strcpy(Name,”Robert”);

5.strlwr( ) function:

This function converts all characters in a string from uppercase to lowercase.

syntax

strlwr(string);

For example:

strlwr(“EXFORSYS”) converts to exforsys.

6.strrev( ) function:

This function reverses the characters in a string.

Syntax

strrev(string);

For ex strrev(“program”) reverses the characters in a string into “margrop”.

7.strupr( ) function:

This function converts all characters in a string from lower case to uppercase.

Syntax

strupr(string);

For example strupr(“exforsys”) will convert the string to EXFORSYS.

Example:-

/* Example program to use string functions*/


#include < stdio.h >

Department of Computer Science Page 16


St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

#include < string.h >


void main()
{
char s1[20],s2[20],s3[20];
int x,l1,l2,l3;
printf(“Enter the strings”);
scanf(“%s%s”,s1,s2);
x=strcmp(s1,s2);
if(x!=0)
{

printf(“\nStrings are not equal\n”);


strcat(s1,s2);
}
else
printf(“\nStrings are equal”);
strcpy(s3,s1);
l1=strlen(s1);
l2=strlen(s2);
l3=strlen(s3);

printf(“\ns1=%s\t length=%d characters\n”,s1,l1);


printf(“\ns2=%s\t length=%d characters\n”,s2,l2);
printf(“\ns3=%s\t length=%d characters\n”,s3,l3);
}

Output:

Enter the strings

hello

hello

Strings are equal

s1=hello length=5 characters

s2=hello length=5 characters

s3=hello length=5 characters

Another output:

Enter the strings

hello
Department of Computer Science Page 17
St.Joseph’s Degree College, Sunkesula Road, Kurnool I B.Sc., II Semester

hai

Strings are not equal

s1=hellohai length=8 characters

s2=hai length=3 characters

s3=hellohai length=8 characters

Department of Computer Science Page 18

You might also like