UNIT II-part 1 Notes

You might also like

Download as doc, pdf, or txt
Download as doc, pdf, or txt
You are on page 1of 19

UNIT II (Part—1) 9L

Operators, Expressions, Precedence and Associativity, Expression Evaluation, Type conversions.

Control Structures: Selection Statements (making decisions) – if, if-else, nested if, else if
ladder and switch statements.

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

OPERATORS

An operator is a symbol that tells the compiler to perform specific mathematical or logical
functions.

The operators are classified into three types based on the number of operands it operates.

1. Unary operator: If operator operates on single operand.

2. Binary operator: If operator operates on two operands.

3. Ternary operator: If operator operates on three operands.

C language is rich in built-in operators .C language provides eight different types of operators.
They are

 Arithmetic Operators

 Relational Operators

 Logical Operators

 Assignment Operators

 Increment and decrement Operators

 Bitwise Operators

 conditional operators

 special Operators
Arithmetic Operators

The various arithmetic operators supported by C language are shown in the following table.

Assume variable A holds 10 and variable B holds 20 then −

Operator Type Description Example

Unary Indicates positive number + A=10


+

Binary Adds two operands. A + B = 30

Unary Indicates negative number -A=-10


Binary Subtracts second operand from the first. A − B = -10

* Binary Multiplies both operands. A * B = 200

/ Binary Divides numerator by de-numerator. B/A=2

Binary Modulus Operator and remainder of after B%A=0


%
an integer division.

Arithmetic operators except Modulus Operator work on integers and float. Modulus operator
works only on integers.

Ex -7%3= -1

7%-3=1

- 7%-3=-1

Ex: 3.2%2 is invalid

Relational Operators

Relational operators are used to compare two values. C language supports six types of relational
operator and all are binary types. The following table shows all the relational operators supported
by C.

Assume variable A holds 10 and variable B holds 20 then


Operator Description Example

== Checks if the values of two operands are equal or not. If yes, then (A = = B) is not
the condition becomes true. true. so 0 is
returned

!= Checks if the values of two operands are equal or not. If the values (A! = B) is true.
are not equal, then the condition becomes true.
So 1 is returned.

> Checks if the value of left operand is greater than the value of right (A > B) is not
operand. If yes, then the condition becomes true. true. So 1 is
returned

< Checks if the value of left operand is less than the value of right (A < B) is true.
operand. If yes, then the condition becomes true. So 1 is returned

>= Checks if the value of left operand is greater than or equal to the (A >= B) is not
value of right operand. If yes, then the condition becomes true. true. so 0 is
returned

<= Checks if the value of left operand is less than or equal to the value (A <= B) is true.
of right operand. If yes, then the condition becomes true. So 1 is returned

Relational operators works on all kinds of data types.

Logical Operators

Logical operators are used to join two conditions. The logical operators either return true (1) or
false (0).C language supports three types of logical operators.

Logical operators work on all data types.

Following table shows the logical operators supported by C language.


Operator Description Type

&& Called Logical AND operator. If both the operands are non-zero, then Binary
the condition becomes true.

|| Called Logical OR Operator. If any of the two operands is non-zero, Binary


then the condition becomes true.

! Called Logical NOT Operator. It is used to reverse the logical state of Unary
its operand. If a condition is true, then Logical NOT operator will
make it false.

The truth table for logical operators is

Cond-1 Cond-2 Cond-1 && cond-2 Cond-1 || cond-2 ! cond-1


F F F F T
F T F T T
T F F T F
T T T T F

Increment and decrement operators

Increment and decrement operators are used to increase or decrease a value by 1.

These operators are unary operators and they work only on integer data types.

Increment operators are of two types pre increment and post increment.

If the operator occurs before operand then the operator is Pre increment operators. Ex ++a

If the operator occurs after operand then the operator is Post increment operators. Ex a++

Decrement operators are of two types pre decrement and post decrement.

If the operator occurs before operand then the operator is Pre decrement operators. Ex --a

If the operator occurs after operand then the operator is Post decrement operators. Ex a--
Operator Type Description

++ Unary Increment operator


increases the integer
value by one.
Ex: If a=5 then a++ will result a=6.
-- Unary Decrement operator If m=4 then ++m will result m=5.
decreases the integer
value by one.

The difference between pre increment and post increment operator lies in the usage of
expressions.

Ex:

int a=5;

y=a++;

then value of a and y after execution is a=6,y=5.

int a=5; y=a; a=a+1


Equivalent code is
y=a++; a=a+1;

Assignment Operators

The assignment operator is used to assign RHS value to LHS variable. The syntax of assignment
operator is

var_name=expression;

where expression can be either constant or variable or expression.

Examples of valid assignment statements:


 a=10;
 a=b;
 a=x+y;
The following table lists the short hand assignment operators supported by the C language –

Operator Description Example

+= Add AND assignment operator. It adds the right operand to the left C += A is equivalent
operand and assign the result to the left operand. to C = C + A

-= Subtract AND assignment operator. It subtracts the right operand from C -= A is equivalent
the left operand and assigns the result to the left operand. to C = C - A

*= Multiply AND assignment operator. It multiplies the right operand with C *= A is equivalent
the left operand and assigns the result to the left operand. to C = C * A

/= Divide AND assignment operator. It divides the left operand with the C /= A is equivalent
right operand and assigns the result to the left operand. to C = C / A

%= Modulus AND assignment operator. It takes modulus using two C %= A is equivalent


operands and assigns the result to the left operand. to C = C % A

<<= Left shift AND assignment operator. C <<= 2 is same as C


= C << 2

>>= Right shift AND assignment operator. C >>= 2 is same as C


= C >> 2

&= Bitwise AND assignment operator. C &= 2 is same as C


=C&2

^= Bitwise exclusive OR and assignment operator. C ^= 2 is same as C =


C^2

|= Bitwise inclusive OR and assignment operator. C |= 2 is same as C =


C|2

Assignment operators work on all data types.


Conditional Operator

The symbol for conditional operator is (?:) and is a ternary operator.

The syntax for conditional operator is

cond?expr1:expr2;

If cond is true then expr1 is evaluated otherwise expr2 is evaluated.

Conditional operator works on all data types.

Bitwise Operators

Bitwise operator works on bits and performs bit-by-bit operation. These operators work
on integer data types.

Operator Description Example

& Binary AND Operator copies a bit to the result if it exists in both operands. (A & B)

| Binary OR Operator copies a bit if it exists in either operand. (A | B)

^ Binary XOR Operator copies the bit if it is set in one operand but not both. (A ^ B)

~ Binary Ones Complement Operator is unary and has the effect of 'flipping' (~A )
bits.

<< Binary Left Shift Operator. The left operands value is moved left by the A << 2
number of bits specified by the right operand.

>> Binary Right Shift Operator. The left operands value is moved right by the A >> 2
number of bits specified by the right operand.
The truth tables for &, |, and ^ is as follows −

p q p&q p|q p^q

0 0 0 0 0

0 1 0 1 1

1 1 1 1 0

1 0 0 1 1

Assume A = 60 and B = 13 in binary format, they will be as follows −

A = 0011 1100

B = 0000 1101

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

A&B = 60&13=0000 1100=12

A|B =60|13= 0011 1101=61

A^B = 60^13=0011 0001=49

~A = 1100 0011=-61

A<<2=60<<2=0011 1100<<2=1111 0000=240

B>>1=13>>1=0000 1101>>1=0000 0110=6

Special Operators

Operator Description Example

sizeof() Returns the size of a variable in bytes. sizeof(a), where a is integer,


will return 4.

& Returns the address of a variable. &a; returns the actual


address of the variable.

, Comma Operator int a,b;

Ex: z=(x=2,y=3,x+y);

z=5;

Operators Precedence in C

Operator precedence determines the grouping of terms in an expression and decides how an
expression is evaluated. Certain operators have higher precedence than others; for example, the
multiplication operator has a higher precedence than the addition operator.

For example, x = 7 + 3 * 2; here, x is assigned 13, not 20 because operator * has a higher
precedence than +, so it first gets multiplied with 3*2 and then adds into 7.

Here, operators with the highest precedence appear at the top of the
table, those with the lowest appear at the bottom. Within an
expression, higher precedence operators will be evaluated first.

Category Operator Associativity

Parenthesis () [] Left to right

Unary (postincrement) ++ (postdecrement) - - Right to left

Unary + - ! ~ (preincrement)++ predecrement- - (type)* & sizeof Right to left

Multiplicative */% Left to right

Additive +- Left to right

Shift << >> Left to right


Relational < <= > >= Left to right

Equality == != Left to right

Bitwise AND & Left to right

Bitwise XOR ^ Left to right

Bitwise OR | Left to right

Logical AND && Left to right

Logical OR || Left to right

Conditional ?: Right to left

Assignment = += -= *= /= %=>>= <<= &= ^= |= Right to left

Comma , Left to right

Type Conversion in C

When variables and constants of different types are combined in an expression then they are
converted to same data type.

The process of converting one predefined type into another is called type conversion.

Type conversion in C can be classified into the following two types:

1. Implicit Type Conversion

2. Explicit Type Conversion

Implicit Type Conversion

When the type conversion is performed automatically by the compiler without programmers
intervention, such type of conversion is known as implicit type conversion or type promotion.
The compiler converts all operands into the data type of the largest operand.

The sequence of rules that are applied while evaluating expressions are given below:

All short and char are automatically converted to int, then,

1. If either of the operand is of type long double, then others will be converted to long
double and result will be long double.

2. Else, if either of the operand is double, then others are converted to double.

3. Else, if either of the operand is float, then others are converted to float.

4. Else, if either of the operand is unsigned long int, then others will be converted to
unsigned long int.

5. Else, if one of the operand is long int, and the other is unsigned int, then

1. if a long int can represent all values of an unsigned int, the unsigned int is
converted to long int.

2. otherwise, both operands are converted to unsigned long int.

6. Else, if either operand is long int then other will be converted to long int.

7. Else, if either operand is unsigned int then others will be converted to unsigned int.

It should be noted that the final result of expression is converted to type of variable on left side
of assignment operator before assigning value to it.

Also, conversion of float to int causes truncation of fractional part, conversion of double to float
causes rounding of digits and the conversion of long int to int causes dropping of excess higher
order bits.

Explicit Type Conversion

The type conversion performed by the programmer by posing the data type of the expression of
specific type is known as explicit type conversion.

The explicit type conversion is also known as type casting.

Type casting in C is done in the following form:

(data_type)expression;

where, data_type is any valid c data type, and expression may be constant, variable or


expression.

For example,
x=(int)a+b*d;

The following rules have to be followed while converting the expression from one type to
another to avoid the loss of information:

1. All integer types to be converted to float.

2. All float types to be converted to double.

3. All character types to be converted to integer.


Control statements enable us to specify the flow of program control; ie, the order in which the
instructions in a program must be executed. They make it possible to make decisions, to perform
tasks repeatedly or to jump from one section of code to another.

There are two types of control statements

1.Decision making statements: Decision making is about deciding the order of execution of
statements based on certain conditions .

2.Iteration statements:Iteration statements are used to perform looping operations until the given
condition is true. 

Decision making statements are of two types-conditional and unconditional decision making
statements.

Conditional Statements in C:

Conditional statements are used to execute a statement or a group of statement based on certain
conditions or test expressions. The various conditional statements are:

1. if statement

i)simple if statement ii)if – else iii) nested if – else iv)else if ladder

2. switch statement

3.conditional or ternary operator

simple if : If test expression is evaluated to true (nonzero), statements inside the body of if is
executed. If test expression is evaluated to false (0), statements inside the body of if is skipped.
If the condition is true then ‘statements of if’ are executed, will be executed, else the control will
be transferred to the next statement after if.

if else statement : In if else if the condition is true then ‘statements of if’ are executed. If it is
false then ‘statements of else’ are executed.

If test expression is true, code inside the body of if statement is executed; and code inside the
body of else statement is skipped.
If test expression is false, code inside the body of else statement is executed; and code inside the
body of if statement is skipped.

else if ladder: When a multipath decision is involved then we use else if ladder.
In else if, if the condition1 is true the statements 1 are executed. If it is false the condition2 in
else if is checked and if it is true it will be executed. If none of the condition is true then default
statements under else are executed.

Nested if - else:

When a series of decisions are involved, we may have to use more than one if-else statement in
nested form
2.Switch: Is a control statement which allows us to make a decision from the number of choices.
expression in the switch must result in integer value. Maximum one of the label values match the
expression value in order for the corresponding statements to execute. Otherwise default
statement executes if present in the switch statement.

Break: When a case is matched then all its statements till break are executed, the switch
terminates, and the flow of control jumps to the next line following the switch statement.

Not every case needs to contain a break. If no break appears, the flow of control will fall
through to subsequent cases until a break is reached.

The switch statement is often faster than nested if...else (not always). If no case is matched then
statements of default are executed.
Advantages and Disadvantages of switch statement over multiple if else statement.

Advantages:
 It is more descriptive
 It saves CPU cycles.
 It enhances readability
Disadvantages:

 Only fixed values can be tested, logical operation (<, >, >/) or relational operation can’t
be.
 Only one variable can be used as parameter for the switch statement, whereas nested ‘if
statement’ allow several conditions with different parameter.
3) Ternary or ? : Operator:

Exp1 ? Exp2 : Exp3;


Where Exp1, Exp2, and Exp3 are expressions. Notice the use and placement of the colon.

The value of a ? expression is determined like this −

 Exp1 is evaluated. If it is true, then Exp2 is evaluated and becomes the value of the entire
? expression.

 If Exp1 is false, then Exp3 is evaluated and its value becomes the value of the
expression.

Unconditional Statements in C:There are three types of unconditional statements

1.goto statement 2.break 3.continue

1) goto statement : In C programming, goto statement is used for altering the normal
sequence of program execution by transferring control to some other part of the program.

syntax:
goto label;

………………..

………………..

label: statement;

In this syntax, label is an identifier.


When, the control of program reaches to goto statement, the control of the program will jump to
the label: and executes the code below it.

Note:

Though goto statement is included in ANSI standard of C, use of goto statement should be
reduced as much as possible in a program.
Reasons to avoid goto statement
 Though, using goto statement give power to jump to any part of program, using goto
statement makes the logic of the program complex and tangled.
 In modern programming, goto statement is considered a harmful construct and a bad
programming practice.
 The goto statement can be replaced in most of C program with the use of break and
continue statements.
 In fact, any program in C programming can be perfectly written without the use of goto
statement.
 All programmer should try to avoid goto statement as possible as they can.

2.Break statements
In C programming, break statement is used with conditional if statement.
The break is used for terminating the loop immediately after it is encountered.

syntax:

break;

The break statement can be used in terminating all three loops for, while and do...while loops.
see jumping out of loop

continue statements

It is sometimes desirable to skip some statements inside the loop. In such cases, continue
statements are used.

syntax: continue;

You might also like