Unit 4
Numeric Data:
Numerical data refers to the data that is in the form of numbers, and not in any
language or descriptive form. Often referred to as quantitative data, numerical data is
collected in number form and stands different from any form of number data types due to its
ability to be statistically and arithmetically calculated.
Numeric data in C:
The primitive numeric data types in C include: – Integer Types: These represent
whole numbers without any fractional or decimal parts. Examples include: – `int`: Used to
store signed integers. – `short`: Used to store small signed integers.
The numeric variable is the number which can take any value like 25,2.36,-4.62,...
Whereas Integer values take only whole number like 4,-8,3,25, ...
So, we can say all integer values are Numeric values but numeric values may not
be integer values.
Basic Data Types
There are four basic data types in C language. They are Integer data, character data,
floating point data and double data types.
a. Character data: Any character of the ASCII character set can be considered as a
character data types and its maximum size can be 1 byte or 8 byte long. ‘Char’ is the keyword
used to represent character data type in C. Char - a single byte size, capable of holding one
character.
b. Integer data: The keyword ‘int’ stands for the integer data type in C and its size is
either 16 or 32 bits. The integer data type can again be classified as
1. Long int - long integer with more digits
2. Short int - short integer with fewer digits.
3. Unsigned int - Unsigned integer
4. Unsigned short int – Unsigned short integer
5. Unsigned long int – Unsigned long integer
As above, the qualifiers like short, long, signed or unsigned can be applied to basic
data types to derive new data types.
int - an Integer with the natural size of the host machine.
c. Floating point data: - The numbers which are stored in floating point representation
with mantissa and exponent are called floating point (real) numbers.
These numbers can be declared as ‘float’ in C.
float – Single – precision floating point number value.
d. Double data : - Double is a keyword in C to represent double precision floating
point numbers.
double - Double – precision floating point number value.
Constans/Literals:
Constants are those, which do not change, during the execution of the program.
Constants may be categorized in to:
• Numeric Constants
• Character Constants
• String Constants
1. Numeric Constants
Numeric constants, as the name itself indicates, are those which consist of numerals,
an optional sign and an optional period. They are further divided into two types:
(a) Integer Constants (b) Real Constants
a. Integer Constants
A whole number is an integer constant Integer constants do not have a decimal
point. These are further divided into three types depending on the number systems they
belong to. They are:
i. Decimal integer constants
ii. Octal integer constants
iii. Hexadecimal integer constants
i. A decimal integer constant is characterized by the following properties
• It is a sequence of one or more digits ([0…9], the symbols of decimal
number system).
• It may have an optional + or – sign. In the absence of sign, the constant is
assumed to be positive.
• Commas and blank spaces are not permitted.
• It should not have a period as part of it.
Some examples of valid decimal integer constants:
456
-123
Some examples of invalid decimal integer constants:
4.56 - Decimal point is not permissible
1,23 - Commas are not permitted
ii. An octal integer constant is characterized by the following properties
• It is a sequence of one or more digits ([0…7], symbols of octal number
system).
• It may have an optional + or – sign. In the absence of sign, the constant is
assumed to be positive.
• It should start with the digit 0.
• Commas and blank spaces are not permitted.
• It should not have a period as part of it.
Some examples of valid octal integer constants:
0456
-0123
+0123
Some examples of invalid octal integer constants:
04.56 - Decimal point is not permissible
04,56 - Commas are not permitted
x34 - x is not permissible symbol
568 - 8 is not a permissible symbol
iii. An hexadecimal integer constant is characterized by the following properties
• It is a sequence of one or more symbols ([0…9][A….Z], the symbols
of Hexadecimal number system).
• It may have an optional + or - sign. In the absence of sign, the constant
is assumed to be positive.
• It should start with the symbols 0X or 0x.
• Commas and blank spaces are not permitted.
• It should not have a period as part of it.
Some examples of valid hexadecimal integer constants:
0x456
-0x123
0x56A
0XB78
Some examples of invalid hexadecimal integer constants:
0x4.56 - Decimal point is not permissible
0x4,56 - Commas are not permitted.
b. Real Constants
The real constants also known as floating point constants are written in two forms:
(i) Fractional form, (ii) Exponential form.
i. Fractional Form
The real constants in Fractional form are characterized by the following
characteristics:
• Must have at least one digit.
• Must have a decimal point.
• May be positive or negative and in the absence of sign taken as positive.
• Must not contain blanks or commas in between digits.
• May be represented in exponential form, if the value is too higher or too low.
Some examples of valid real constants:
456.78
-123.56
Some examples of invalid real constants:
4.56 - Blank spaces are not permitted
4,56 - Commas are not permitted
456 - Decimal point missing
ii. Exponential Form
The exponential form offers a convenient way for writing very large and small
real constant. For example, 56000000.00, which can be written as 0.56 *, 108 is
written as 0.56E8 or 0.56e8 in exponential form. 0.000000234, which can be written
as 0.234 * 10-6 is written as 0.234E-6 or 0.234e-6 in exponential form. The letter E or
e stand for exponential form. A real constant expressed in exponential form has two
parts: (i) Mantissa part, (ii) Exponent part. Mantissa is the part of the real constant to
the left of E or e, and the Exponent of a real constant is to the right of E or e. Mantissa
and Exponent of the above two number are shown below
In the above examples, 0.56 and 0.234 are the mantissa parts of the first and second
numbers, respectively, and 8 and -6 are the exponent parts of the first and second
number, respectively.
The real constants in exponential form and characterized by the following
characteristics:
• The mantissa must have at least one digit.
• The mantissa is followed by the letter E or e and the exponent.
• The exponent must have at least one digit and must be an integer.
• A sign for the exponent is optional.
Some examples of valid real constants:
3E4
23e-6
0.34E6
Some examples of invalid real constants:
23E - No digit specified for exponent
23e4.5 - Exponent should not be a fraction
23,4e5 - Commas are not allowed
256*e8- * not allowed
2. Character Constants
Any character enclosed with in single quotes (‘) is called character constant.
A character constant:
• May be a single alphabet, single digit or single special character placed with
in single quotes.
• Has a maximum length of 1 character.
Here are some examples,
• ‘C’
• ‘c’
• ‘:’
• ‘*’
3. String Constants
A string constant is a sequence of alphanumeric characters enclosed in double quotes
whose maximum length is 255 characters.
Following are the examples of valid string constants:
• “My name is Krishna”
• “Bible”
• “Salary is 18000.00”
Following are the examples of invalid string constants:
My name is Krishna - Character are not enclosed in double quotation marks.
“My name is Krishna - Closing double quotation mark is missing.
‘My name is Krishna’ - Characters are not enclosed in double quotation marks
ARRAY
Array can be defined as a collection of data objects which are stored in consecutive
memory locations with a common variable name.
OR
Array can be defined as a group of values referred by the same variable name.
OR
An Array can be defined as a collection of data objects which are stored in
consecutive memory locations with a common variable name. The individual values present
in the array are called elements of array. The array elements can be values or variables also.
Types of Arrays
Basically arrays can divide in to
1. One Dimensional Array
An array with only one subscript is called as one-dimensional array or 1- d array. It is
used to store a list of values, all of which share a common name and are separable by
subscript values
2. Two Dimensional Array
An array with two subscripts is termed as two-dimensional array. A two-dimensional array,
it has a list of given variable -name using two subscripts. We know that a one-dimensional
array can store a row of elements, so, a two-dimensional array enables us to store multiple
rows of elements.
Initialization of Array
Array can be made initialized at the time of declaration itself. The general form of
array initialization is as below
type name[n] = [ element1, element2, …. element n];
The elements 1, element2… element n are the values of the elements in the array
referenced by the same.
Example1:- int codes[5] = [ 12,13,14,15,16];
Example2:- float a[3] = [ 1.2, 1.3, 1.4];
Example3:- char name [5] = [ ‘S’, ‘U’, ‘N’, ‘I’, ‘L’];
In above examples, let us consider one, it a character array with 5 elements and all the
five elements area initialized to 5 different consecutive memory locations.
name[0] = ‘C’
name[1] = ‘O’
name[2] = ‘L’
name[3] = ‘L’
name[4] = ‘E’
name[5] = ‘G’
name[6] = ‘E’
Rules for Array Initialization
1. Arrays are initialized with constants only.
2. Arrays can be initialized without specifying the number of elements in square brackets and
this number automatically obtained by the compiler.
3. The middle elements of an array cannot be initialized. If we want to initialize any middle
element then the initialization of previous elements is compulsory.
4. If the array elements are not assigned explicitly, initial values will be set to zero
automatically.
5. If all the elements in the array are to be initialized with one and same value, then repletion
of data is needed.
Declaration of Array
The array must be declared as other variables, before its usage in a C program. The
array declaration included providing of the following information to C compiler.
- The type of the array (ex. int, float or char type)
- The name of the array ( ex A[ ],B[ ] , etc)
- Number of subscripts in the array ( i.e whether one – dimensional or Two-
dimensional)
- Total number of memory locations to be allocated.
The name of the array can be kept by the user (the rule similar to naming to variable).
There is no limit one on dimensions as well as number of memory locations and it
depends on the capacity of computer main memory.
The general form for array declaration is
Type name[n] ; { one dimensional array}
Ex : int marks[20];
char name[15];
float values [ 10];
An array with only one subscript is called as one-dimensional array or 1-d array. It is
used to store a list of values, all of which share a common name and are separable by
subscript values.
Declaration of One-dimensional Arrays:
The general form of declaring a one-dimensional array is
Where data-type refers to any data type supported by C, array-name should be a valid
C identifier; the size indicates the maximum number of storage locations (elements) that can
be stored.
Each element in the array is referenced by the array name followed by a pair of square
brackets enclosing a subscript value. The subscript value is indexed from 0 to size -1. When
the subscript vale is 0, first element in the array is selected, when the subscript value is 1,
second element is selected and so on.
Example
int x [6];
Here, x is declared to be an array of int type and of size six. Six contiguous
memory locations get allocated as shown below to store six integer values.
Each data item in the array x is identified by the array name x followed by a pair of
square brackets enclosing a subscript value. The subscript value is indexed from 0 to 5. i.e.,
x[0] denotes first data item, x[1] denotes second data
item and x[5] denotes the last data item.
Initialization of One-Dimensional Arrays:
Just as we initialize ordinary variables, we can initialize one-dimensional arrays also,
i.e., locations of the arrays can be given values while they are declared.
The general form of initializing an array of one-dimension is as follows:
data - type array - name [size] = {list of values};
The values in the list are separated by commas.
Example
int x [6] = {1, 2, 3, 4, 5, 6 };
as a result of this, memory locations of x get filled up as follows:
Points to be considered during the declaration
1. If the number of values in initialization value - is less then the size of an array, only
those many first locations of the array are assigned the values. The remaining
locations are assigned zero.
Example: int x [6] = {7, 8, 6 };
The size of the array x is six, initialization value - consists of only three locations get
0 assigned to them automatically, as follows:
2. If the number of values listed within initialization value - list for anyarray is greater
than the six the array, compiler raises an error.
Example: int x [6] = {1, 2, 3, 4, 5, 6, 7, 8 };
The size of the array x is six. But the number of values listed within the initialization -
list is eight. This is illegal.
3. If a static array is declared without initialization value - list then the all locations are
set to zero.
Example: static int x [6];
4. If size is omitted in a 1-d array declaration, which is initialized, the compiler will
supply this value by examining the number of values in the initialization value - list.
Example: int x [ ] = {1, 2, 3, 4, 5, 6 };
Since the number of values in the initialization value-list for the array x is six, the size
of x is automatically supplied as six.
5. There is no array bound checking mechanism built into C-compiler. It is the
responsibility of the programmer to see to it that the subscript value does not go
beyond size-1. If it does, the system may crash.
Example: int x [6];
x [7] = 20;
Here, x [7] does not belong to the array x, it may belong to some other program (for
example, operating system) writing into the location may lead to unpredictable results
or even to system crash.
6. Array elements can not be initialized selectively.
Example:
An attempt to initialize only 2nd location is illegal, i.e.,
int x [6] = { , 10 } is illegal.
Similar to arrays of int type, we can even declare arrays of other data types supported
by C, also.
Example: char ch [6];
ch is declared to be an array of char type and size 6 and it can accommodate 6
characters.
Example: float x [6];
x is declared to be an array of float type and size 6 and it can accommodate 6 values
of float type. Following is the scheme of memory allocation for the array x:
Note: A one array is used to store a group of values. A loop (using, for loop) is used
to access each value in the group.
Example: Program to illustrate declaration, initialization of a 1-d array
#include<stdio.h>
#include<conio.h>
void main( )
{
int i, x [6] = {1, 2, 3, 4, 5, 6 };
clrscr( );
printf(“The elements of array x \n”);
for(i=0; i<6; i++)
printf(“%d”, x [i]);
getch( );
}
Input – Output:
The elements of array x
123456
Two Dimensional Array:
An array with two subscripts is termed as two-dimensional array.
A two-dimensional array, it has a list of given variable -name using two subscripts.
We know that a one-dimensional array can store a row of elements, so, a two-dimensional
array enables us to store multiple rows of elements.
Example: Table of elements or a Matrix.
Syntax of two-dimensional arrays:
The syntax of declaring a two-dimensional array is:
Where, data-type refers to any valid C data type, array -name refers to any valid C
identifier, row size indicates the number of rows and column size indicates the
number of elements in each column.
Row size and column size should be integer constants.
Total number of location allocated = (row size * column size).
Each element in a 2-d array is identified by the array name followed by a pair of
square brackets enclosing its row-number, followed by a pair of square brackets
enclosing its column-number.
Row-number range from 0 to row size-1 and column-number range from 0 to column
size-1.
Example: int y [3] [3];
y is declared to be an array of two dimensions and of data type Integer (int),
row size and column size of y are 3 and 3, respectively. Memory gets allocated to
store the array y as follows. It is important to note that y is the common name shared
by all the elements of the array.
Each data item in the array y is identifiable by specifying the array name y followed
by a pair of square brackets enclosing row number, followed by a pair of square
brackets enclosing column number.
Row-number ranges from 0 to 2. that is, first row is identified by rownumber 0,
second row is identified by row-number 1 and so on.
Similarly, column-number ranges from 0 to 2. First column is identified by column-
number 0, second column is identified by column-number 1 and so on.
x [0] [0] refers to data item in the first row and first column
x [0] [2] refers to data item in the first row and third column
x [2] [3] refers to data item in the third row and fourth column
x [3] [4] refers to data item in the fourth row and fifth column
Initialization of Two-Dimensional Array
There are two forms of initializing a 2-d array.
First form of initializing a 2-d array is as follows:
Where, data-name refers to any data type supported by C. Array-name refers to any
valid C identifier. Row size indicates the number of rows, column size indicates the
number of columns of the array. initialier-list is a comma separated list of values.
If the number of values in initializer-list is equal to the product of row size and
column size, the first row size values in the initializer-list will be assigned to the first
row, the second row size values will be assigned to the second row of the array and so
on
Example: int x [2] [4] = {1, 2, 3, 4, 5, 6, 7, 8 };
Since column size is 4, the first 4 values of the initializer-list are assigned to the first
row of x and the next 4 values are assigned to the second row of x as shown
hereinafter
1234
5678
Note: If the number of values in the initializer-list is less than the product of rowsize
and colsize, only the first few matching locations of the array would get values from
the initializer-list row-wise. The trailing unmatched locations would get zeros.
Example: int x [2] [4] = {1, 2, 3, 4};
The first row of x gets filled with the values in the initializer-list. The second row gets
filled with zeros
The second form of initializing a 2-d array is as follows:
data-type array-name [rowsize] [colsize] = { {initializer-list1}, {initializer-list2},
………};The values in initializerlist 1
are assigned to the locations in the first row. The values in initializer-list2 are
assigned to the locations in the second row and so on.
Example: int x [2] [4] = { { 1, 2, 3, 4 }, { 5, 6, 7, 8 } };
As a result of this, the array x gets filled up as follows:
Note
1. If the number of values specified in any initializer-list is less than colsize of x, only
those may first locations in the corresponding row would get these values. The
remaining locations in that row would get 0.
Example: int x [2] [4] = { { 1, 2, 3 }, { 4, 5, 6, 7 } };
Since the first initializer-list has only three values, x [0] [0] is set to 1, x [0][1] is set
to 2, x [0] [2] is set to 3 and the fourth location in the first row is automatically set to
0.
2. If the number of values specified in any initializer-list is more than colsize of x,
compiler reports an error.
Example: int x [2] [4] = { { 1, 2, 3, 4, 5 }, { 6, 7, 8, 9 } };
colsize is 4, but the number of values listed in the first row is 5. This results in
compilation error.
3. Array elements can not be initialized selectively.
4. It is the responsibility of the programmer to ensure that the array bounds do not
exceed the rowsize and colsize of the array. If they exceed, unpredictable results may
be produced and even the program can result in system crash sometimes.
5. A 2-d array is used to store a table of values (matrix).
Similar to 2-d arrays of int type, we can declare 2-arrays of any other data type
supported by C, also.
Example: float x [4] [5];
x is declared to be 2-d array of float type with 4 rows and 5 columns double y [4] [5];
y is declared to be 2-d arrays of double type with 4 rows and 5 columns
Note
A two-dimensional array is used to store a table of values. Two loops (using for
loops) are used to access each value in the able, first loop acts as a row selector and
second loop acts as a column selector in the table.
DECLARE, INITIALIZE ARRAY OF CHAR TYPE
Declaration of Array of char type: A string variable is any valid C variable name and
is always declared as an array. The syntax of declaration of a string variable is:
char string-name[size];
The size determines the number of character in the string name.
Example: An array of char type to store the above string is to be declared as follows:
char str[8];
An array of char is also called as a string variable, since it can store a string and it
permits us to change its contents. In contrast, a sequence of characters enclosed within
a pair of double quotes is called a string constant.
Example: “Program” is a string constant.
Initialization of Arrays of char Type
The syntax of initializing a string variable has two variations:
Variation 1
char str1 [6] = { ‘H’, ‘e’, ‘l’, ‘l’, ‘o’, ‘\0’};
Here, str1 is declared to be a string variable with size six. It can store
maximum six characters. The initializer – list consists of comma separated character
constants. Note that the null character ‘\0’ is clearly listed. This is required in this
variation.
Variation 2
char str2 [6] = { “Hello” };
Here, str2 is also declared to be a string variable of size six. It can store
maximum six characters including null character. The initializer-list consists of a
string constant. In this variation, null character ‘\0’ will be automatically added to the
end of string by the compiler.
In either of these variations, the size of the character array can be skipped, in which
case, the size and the number of characters in the initializer-list would be
automatically supplied by the compiler.
Example
char str1 [ ] = { “Hello” };
The size of str1 would be six, five characters plus one for the null character ‘\0’.
char str2 [ ] = { ‘H’, ‘e’, ‘l’, ‘l’, ‘o’, ‘\0’};
The size of str2 would be six, five characters plus one for null character ‘\0’.
Example 1
Program to sort a list of numbers.
#include<stdio.h>
#include<conio.h>
void main( )
{
int x [6], n, i, j, tmp;
clrscr( );
printf (“Enter the no. of elements \n”);
scanf (“%d”, & n);
printf (“Enter %d numbers \n”, n);
for (i=0; i<n; i++)
scanf(“%d”, & x [i]);
/* sorting begins */
for (i=0; i<n; i++)
for (j=i + 1; j<n; j++)
if (x[i]>x[j])
{
tmp = x [i];
x [i] = x [j];
x [j] = tmp;
}
/* sorting ends */
printf (“sorted list \n”);
for (i=0; i<n; i++)
printf (“%d”, x [i]);
getch( );
}
Input – Output
Enter the no. of elements
5
Enter 5 numbers
10 30 20 50 40
Sorted list
10 20 30 40 50
Example 2
Write a ‘C’ program to find the average marks of ‘n’ students of five subjects
for each subject using arrays.
#include <stdio.h>
void main( )
{
int Sno, S1,S2,S3;
float tot, avg;
char sname[10];
printf(“Enter student no;”);
scanf(“%d”, & Sname);
printf(“Enter subject - 1, sub - 2, sub - 3 marks;”);
scanf(“%d %d %d”, &s1,&s2,&s3);
tot = S1+S2+S3;
avg = tot/3;
printf(“total = %f”, tot);
printf(“Average = %f”, avg);
}