Module 2 - Arrays & Functions
Module 2 - Arrays & Functions
Strings
Need of Array Variable
Suppose we need to store rollno of the student in the integer variable.
Declaration
int rollno;
Now we need to store rollno of 100 students.
Declaration
int rollno101, rollno102, rollno103,
rollno104...;
This is not appropriate to declare these many integer variables.
e.g. 100 integer variables for rollno.
Solution to declare and store multiple variables of similar type is an
array.
An array is a variable that can store multiple values.
Definition: Array
An array is a fixed size sequential collection of elements of same data
type grouped under single variable name.
float
Initialing and Accessing an Array
Declaring, initializing and accessing single integer variable
int mark=90; //variable mark is initialized with value 90
printf("%d",mark); //mark value printed
1 // data[2][4]
2 can be initialized like this also
int data[2][4]={{1,2,3,4},{5,6,7,8}};
Read(Scan) 2D Array Elements
Program
1 void main(){
2 int data[3][3],i,j;
3 for(i=0;i<3;i++)
4 {
5 for(j=0;j<3;j++)
6 { Output
7 printf("Enter array element="); Enter array element=1
8 scanf("%d",&data[i][j]); Enter array element=2
9 } Enter array element=3
10 } Enter array element=4
11 for(i=0;i<3;i++) Enter array element=5
12 { Enter array element=6
13 for(j=0;j<3;j++) Enter array element=7
14 { Enter array element=8
15 printf("%d",data[i][j]); Enter array element=9
16 } 123
17 printf("\n"); 456
18 } 789
19 }
Develop a program to count number of positive, negative and zero
elements from 3 X 3 matrix
Program
1 void main(){
2 int data[3][3],i,j,pos=0,neg=0,zero=0; Output
3 for(i=0;i<3;i++) Enter array element=9
4 { Enter array element=5
5 for(j=0;j<3;j++) Enter array element=6
6 { Enter array element=-3
7 printf("Enter array element="); Enter array element=-7
8 scanf("%d",&data[i][j]); Enter array element=0
9 if(data[i][j]>0) Enter array element=11
10 pos=pos+1; Enter array element=13
11 else if(data[i][j]<0) Enter array element=8
12 neg=neg+1; positive=6,negative=2,zero
13 else =1
14 zero=zero+1;
15 }
16 }
17 printf("positive=%d,negative=%d,zero=
18 %d",pos,neg,zero);
}
Practice Programs
1. Develop a program to perform addition of two matrix.
2. Develop a program to perform multiplication of two matrix.
String
(Character Array)
Definition: String
A String is a one-dimensional array of characters terminated by a
null('\0').
[0] [1] [2] … [9]
char name[10]
;
Each character in the array occupies one byte of memory, and the last
character must always be null('\0').
The termination character ('\0') is important in a string to identify
where the string ends.
[0] [1] [2] [3] [4] [5] [6] [7] [8] [9]
name[10 D A R S H A N \0
]
Declaring & Initializing String
Declaration
char name[10]
;
Initialization method 1:
char name[10]={'D','A','R','S','H','A','N','
\0'};
Initialization method 2:
char name[10]="DARSHAN";
//'\
0' will be automatically inserted at the end in this type of declarati
on.
[0] [1] [2] [3] [4] [5] [6] [7] [8] [9]
name[10 D A R S H A N \0
]
Read String: scanf()
Program
Output
1 void main()
2 { Enter name: Vellore
3 char name[10]; Name=Vellore
4 printf("Enter name:"); Output
5 scanf("%s",name);
Enter name: VIT Chennai
6 printf("Name=%s",name);
Name=VIT
7 }
Program
1 #include <stdio.h> Output
2 #include <string.h> //header file for string functions Enter string: VIT
3 void main() Chennai
4 { 11
5 char s1[10];
6 printf("Enter string:");
7 gets(s1);
8 printf("%d",strlen(s1)); // returns length of s1 in in
9 teger
}
String Handling Functions: strcmp()
strcmp(s1,s2): Returns 0 if s1 and s2 are the same.
Returns less than 0 if s1<s2.
Returns greater than 0 if s1>s2.
Program
1 void main() Output
2 { Enter string-
3 char s1[10],s2[10]; 1:Computer
4 printf("Enter string-1:"); Enter string-
5 gets(s1); 2:Computer
6 printf("Enter string-2:"); Output
Strings are same
7 gets(s2); Enter string-
8 if(strcmp(s1,s2)==0) 1:Computer
9 printf("Strings are same"); Enter string-
10 else 2:Computer
11 printf("Strings are not same"); Strings are same
12 }
String Handling Functions
For examples consider: char s1[]="Their",s2[]="There";
Syntax Description
strcpy(s1,s2) Copies 2nd string to 1st string.
strcpy(s1,s2) copies the string s2 in to string s1 so s1 is now “There”. s2
remains unchanged.
strchr(s1,c) Returns a pointer to the first occurrence of a given character in the string s1.
printf("%s",strchr(s1,'i'));
Output : ir
strstr(s1,s2) Returns a pointer to the first occurrence of a given string s2 in string s1.
printf("%s",strstr(s1,"he"));
Output : heir
String Handling Functions (Cont…)
For examples consider: char s1[]="Their",s2[]="There";
Syntax Description
strrev(s1) Reverses given string.
strrev(s1); makes string s1 to “riehT”
strlwr(s1) Converts string s1 to lower case.
printf("%s",strlwr(s1)); Output :
their
strupr(s1) Converts string s1 to upper case.
printf("%s",strupr(s1)); Output : THEIR
strncpy(s1,s2,n Copies first n character of string s2 to string s1
) s1=""; s2="There";
strncpy(s1,s2,2);
printf("%s",s1); Output : Th
strncat(s1,s2,n Appends first n character of string s2 at the end of string s1.
) strncat(s1,s2,2);
printf("%s", s1); Output :
TheirTh
String Handling Functions (Cont…)
For examples consider: char s1[]="Their",s2[]="There";
Syntax Description
strncmp(s1,s2,n Compares first n character of string s1 and s2 and returns similar result as
) strcmp() function.
printf("%d",strcmp(s1,s2,3));
Output : 0
strrchr(s1,c) Returns the last occurrence of a given character in a string s1.
printf("%s",strrchr(s2,'e')); Output
: ere
Functions
What is Function?
A function is a group of statements that perform a specific task.
It divides a large program into smaller parts.
A function is something like hiring a person to do a specific job for you.
Every C program can be thought of as a collection of these functions.
Program execution in C language starts from the main function.
Syntax
void main()
{
// body part
}
Why function ?
Avoids rewriting the same code over and over.
Using functions it becomes easier to write programs and keep track of what they
doing.
Types of Function
Function
void main()
{
....
func1(); Function call
}
void func1()
{
.... Function definition
//function body
....
}
Function Prototype
A function Prototype also know as function declaration.
A function declaration tells the compiler about a function name and how to call the
function.
It defines the function before it is being used or called.
A function prototype needs to be written at the beginning of the program.
Syntax Example
return-type function-name (arg-1, arg 2, void addition(int, int);
…);
Function Definition
A function definition defines the functions header and body.
A function header part should be identical to the function prototype.
Function return type
Function name
List of parameters
A function body part defines function logic.
Function statements
Syntax Example
return-type function-name (arg-1, arg 2, void addition(int x, int y)
…) {
{ printf("Addition is=%d“,
//... Function body (x+y)); }
}
WAP to add two number using add(int, int)
Function
Program Output
1 #include <stdio.h> Addition is = 11
2 void add(int, int); // function declaration
3
4 void main()
5 {
6 int a = 5, b = 6;
7 add(a, b); // function call
8 }
9
10 void add(int x, int y) // function definition
11 {
12 printf("Addition is = %d", x + y);
13 }
Actual parameters and Formal parameters
Values that are passed to the called function from the main function
are known as Actual parameters.
The variables declared in the function prototype or definition are
known as Formal parameters.
When a method is called, the formal parameter is temporarily "bound"
to the actual parameter.
Syntax
return;
Or
return (expression);
WAP to find maximum number from two number
Program Output
1 #include <stdio.h> Max value is : 200
2 int max(int a, int b);
3 void main()
4 {
5 int a = 100;
6 int b = 200;
7 int maxvalue;
8 maxvalue = max(a, b);
9 printf("Max value is : %d\n",
10 maxvalue);
11 }
12 int max(int a, int b)
13 {
14 if (a > b)
15 return a; // return a
16 else
17 return b; // return b
18 }
Category of Function
(1) Function with no argument and but no return value
No
void main() Input void fun1()
{ {
..... .....
No return .....
fun1();
value .....
.....
} }
External Data Zero Global Till end of program extern int var;
{extern} segment Multiple file
void main()
{
....
func1();
.... Function
} call
void func1()
{ Recursive
.... function call
func1();
....
}
Properties of Recursion
A recursive function can go infinite like a loop. To avoid infinite running
of recursive function, there are two properties that a recursive function
must have.
Base Case or Base criteria
It allows the recursion algorithm to stop.
A base case is typically a problem that is small enough to solve directly.
Progressive approach
A recursive algorithm must change its state in such a way that it moves forward
to the base case.
Recursion - factorial example
The factorial of a integer n, is Recursive trace
product of
n * (n-1) * (n-2) * …. * 1 Final Ans 5 *24 = 120
Recursive definition of factorial Fact(5)
n! = n * (n-1)! return 4 * 6 = 24
call
Example
3! = 3 * 2 * 1 Fact(4)
3! = 3 * (2 * 1) return 3 * 2 = 6
call
3! = 3 * (2!)
Fact(3)
return 2 * 1 = 2
call
Fact(2)
return 1
call
Fact(1)
WAP to find factorial of given number using
Recursion
Program Output
1 #include <stdio.h> Enter the number? 5
2 int fact(int); factorial = 120
3 void main()
4 {
5 int n, f;
6 printf("Enter the number?\n");
7 scanf("%d", &n);
8 f = fact(n);
9 printf("factorial = %d", f);
10 }
11 int fact(int n)
12 {
13 if (n == 0)
14 return 1;
15 else if (n == 1)
16 return 1;
17 else
18 return n * fact(n - 1);
19 }
Recursion - Fibonacci example
A series of numbers , where Recursive trace
next number is found by adding
the two number before it. Fib(4) Final Ans. 3