OPERATORS.

Slides:



Advertisements
Similar presentations
Arithmetic Calculations
Advertisements

True or false A variable of type char can hold the value 301. ( F )
Lecture 071 CS 192 Lecture 7 Winter 2003 December 15-16, 2003 Dr. Shafay Shamail.
1 9/20/06CS150 Introduction to Computer Science 1 Review: Exam 1.
© Janice Regan, CMPT 102, Sept CMPT 102 Introduction to Scientific Computer Programming Expressions and Operators Program Style.
Data types and variables
Expressions An expression is a sequence of operands and operators that reduces to a single value expression operator operand An operator is a language-specific.
Chapter 2 Data Types, Declarations, and Displays
Performing Computations C provides operators that can be applied to calculate expressions: example: tax is 8.5% of the total sale expression: tax =
CHAPTER 8 OPERATORS AND EXPRESSIONS IN C++. OPERATORS The operations (specific task) are represented by operators and the objects of the operation(s)
1 Chapter Two Using Data. 2 Objectives Learn about variable types and how to declare variables Learn how to display variable values Learn about the integral.
Chapter 2 Data Types, Declarations, and Displays.
Objectives You should be able to describe: Data Types
Operaciones y Variables
Chapter 4: Operators Department of Computer Science Foundation Year Program Umm Alqura University, Makkah Computer Programming Skills /1436.
© Janice Regan, CMPT 128, Jan CMPT 128: Introduction to Computing Science for Engineering Students Data representation and Data Types Variables.
CHAPTER:8 OPERATORS AND EXPRESSION IN C++ Prepared By Prepared By : VINAY ALEXANDER ( विनय अलेक्सजेंड़र ) PGT(CS),KV JHAGRAKHAND.
Chapter 2 part #4 Operator
2440: 211 Interactive Web Programming Expressions & Operators.
Object-Oriented Programming Using C++ Third Edition Chapter 2 Evaluating C++ Expressions.
CSE1222: Lecture 4The Ohio State University1. Mathematical Functions (1)  The math library file cmath Yes, this is a file with definitions for common.
Operators Using Java operators An operator takes one or more arguments and produces a new value. All operators produce a value from their.
CHAPTER 2 PART #4 OPERATOR 2 nd semester King Saud University College of Applied studies and Community Service Csc 1101 By: Asma Alosaimi Edited.
Knowledge Base C++ #include using std namespace; int main(){} return 0 ; cout
C++ Basics Tutorial 6 Operators. What are going to see today? Assignment operator(=) Arithmetic operators(+,-,*,/,%) Compound assignment(+=,-=,*=……..)
CPS120: Introduction to Computer Science Operations Lecture 9.
C Operators. CONTENTS C OPERATORS TYPES OF OPERATOR UNARY BINARY TERNARY ARITHMATIC RELATIONAL LOGICAL.
COMPUTER PROGRAMMING. variable What is variable? a portion of memory to store a determined value. Each variable needs an identifier that distinguishes.
Operators Precedence - Operators with the highest precedence will be executed first. Page 54 of the book and Appendix B list C's operator precedence. Parenthesis.
CHAPTER 1.3 THE OPERATORS Dr. Shady Yehia Elmashad.
PHY-102 SAPVariables and OperatorsSlide 1 Variables and Operators In this section we will learn how about variables in Java and basic operations one can.
Chapter 6 Mathematical Operations. 6.1 Mathematical Expressions In mathematics this expression is valid 0 = -4y + 5 It is invalid in programming Left.
1 Expressions. 2 Variables and constants linked with operators  Arithmetic expressions Uses arithmetic operators Can evaluate to any value  Logical.
CSCI 3133 Programming with C Instructor: Bindra Shrestha University of Houston – Clear Lake.
Recap……Last Time [Variables, Data Types and Constants]
Operators & Expressions
Tokens in C  Keywords  These are reserved words of the C language. For example int, float, if, else, for, while etc.  Identifiers  An Identifier is.
1 CS161 Introduction to Computer Science Topic #6.
0 Chap.2. Types, Operators, and Expressions 2.1Variable Names 2.2Data Types and Sizes 2.3Constants 2.4Declarations 2.5Arithmetic Operators 2.6Relational.
ECE 103 Engineering Programming Chapter 4 Operators Herbert G. Mayer, PSU CS Status 6/19/2015 Initial content copied verbatim from ECE 103 material developed.
STRUCTURED PROGRAMMING C++ Operators. Content 2  C++ operators  Assignment operators  Arithmetic operators  Increment and decrement operators  Decision.
Unary, Binary, logical Operations, Explicit type conversion Lecture 6 Instructor: Haya Sammaneh.
Programming Principles Operators and Expressions.
Operators A binary operator combines two values to get one result: x OP y where OP is any binary operators such as +, -, *, /, ==, !=, >, &&, or even =.
Prepared By: K. U. Khimani Assistant Professor IT Department.
OPERATORS IN C CHAPTER 3. Expressions can be built up from literals, variables and operators. The operators define how the variables and literals in the.
1 Chapter 3 – Operators and Expressions Outline 3.1Introduction 3.2Arithmetic operators 3.3Relational operators 3.4Logical operators 3.5Assignment operators.
ECE 103 Engineering Programming Chapter 4 Operators Herbert G. Mayer, PSU Status 6/10/2016 Initial content copied verbatim from ECE 103 material developed.
Variables, Operators, and Expressions
CompSci 230 S Programming Techniques
Chapter 7: Expressions and Assignment Statements
Lecture 3 Java Operators.
Computing Fundamentals
Relational Operations
Chapter 7: Expressions and Assignment Statements
Operators and Expressions
Expressions Chapter 4 Copyright © 2008 W. W. Norton & Company.
Character Set The character set of C represents alphabet, digit or any symbol used to represent information. Types Character Set Uppercase Alphabets A,
C Operators, Operands, Expressions & Statements
Chapter-3 Operators.
Introduction to Programming – 4 Operators
Chapter 3 Operators and Expressions
C++ Programming Language Lecture 4 C++ Basics – Part II
OPERATORS AND EXPRESSIONS IN C++
ENERGY 211 / CME 211 Lecture 5 October 1, 2008.
OPERATORS in C Programming
Operator King Saud University
DATA TYPES There are four basic data types associated with variables:
Expressions An Expression is a sequence of operands and operators that reduces to a single value. An operator is a language-specific syntactical token.
OPERATORS in C Programming
Presentation transcript:

OPERATORS

What are operators? In c++ the operators are mostly made of signs. It relies less on English words. They are to perform specific tasks on the operands.

Classification of Operators The operators can be classified based on No of Operands Unary Operators Binary Operators Ternary Operators Type of operations Arithmatic Operators Relational Operators Logical Operators

Classification of Operators (No of Operands) Operand is constant or variable used by the operator. Unary Operators : These are the operators that act on one operand. Binary Operators : These are the operators that act on two operands. Ternary Operators : These are the operators that act on three operands.

Classification of Operators (Type of Operation) Based on the type of operations the operators are classified as Arithmatic Operators : These operators give results in numeric form Relational Operators : These operators give results in form of true/false. Logical Operators : These operators too give result in true/false form.

ARITHMATIC OPERATORS

Assignment Operator (=) The assignment operator assigns a value to a variable. The assignment operation always takes place from right to left, and never the other way: E.g. x=5; This statement assigns the integer value 5 to the variable a. 5=x; // is wrong

Take a look at this example // assignment operator #include <iostream> using namespace std; int main () { int a, b; // values of a & b are unknown a = 10; // a=10 & value of b is unknown b = 4; // a=10, b=4 a = b; // a=4, b=4 b = 7; // a=4, b=7 cout << "a:"; cout << a; cout << " b:"; cout << b; return 0; }

OUTPUT The output will be a:4b:7 Can you predict output of the program? The output will be a:4b:7 Notice how a was not affected by the final modification of b, even though we declared a = b earlier (that is because of the right-to-left rule).

Assignment Operator Assignment operator can be chained together. E.g. A = B = C = 10; E.g. A = B = C = 10; Variables can be intialised by means of assignment operator only. E.g. int a = 10;

ARITHMATIC OPERATORS UNARY + : The operator unary + precedes an operand. The operand must be arithmatic or pointer. E.g. If a=8 then +a means 8 If a=-2 then +a means -2 UNARY - : The operator unary + precedes an operand. The operand must be arithmatic. E.g. If a=8 then -a means -8 If a=-2 then -a means 2

ARITHMATIC OPERATORS Addition/subtraction/multiplication/division : These are binary operators. The operands for these operators may be integer or float type. E.g. If a = 10 and b = 5 a+b results in 15 a-b results in 5 a*b results in 50 a/b results in 2

DIVIDE BY ZERO ! Care should be taken to avoid 'divide by zero' error which is caused if in a/b, b=0. e.g. cout <<3/0; // This statement will cause 'Divide by Zero' error.

ARITHMATIC OPERATORS Modulus operator (%) : Its result is the remainder of dividing the first operand by second. Both operands must of integer type. E.g. 19%6 results in 1 0%3 results in 0

Increment/ Decrement Operators (++/--) These are the special operators available in c and c++ languages. This operator increases or decreases value of variable by 1. A characteristic of the operator is that it can be prefixed or suffixed. Thus it can be written as ++a or a++.

!Important It is important to note that a postfix increment or decrement expression evaluates to the value of the expression prior to application of the respective operator. The increment or decrement operation occurs after the operand is evaluated. This issue arises only when the postfix increment or decrement operation occurs in the context of a larger expression. Thus , a++; ++a; Both will work exactly same way

Let us see what it means. Example 1 Example 2 b=3; a=++b; cout << “a=”<<a<<” b=”<<b; b=3; a=b++; cout << “a=”<<a<<”--b=”<<b; a=? b=3 a=? b=3 a=4 b=4 a=3 b=4 Output Output a=4 b=4 a=3 b=4

! NOTE The postfix increment or decrement operator follows use and then change rule. The prefix increment or decrement operator follows change and then use rule. The postfix operator has higher precedence than prefix. So postfix operators will get evaluated before prefix. Try solving Worksheet 1 at this point.

RELATIONAL OPERATORS

Relational Operators These operators determine the relation between the operands. The result of relational operators is in form of true(1) or false(0). Operator Meaning < Less Than > Greater Than <= Less Than or equal to >= Greater Than or equal to == Equal to != Not equal to

! NOTE Avoid equality comparison on floating point numbers. Do not confuse between = (assignment operator) and == (equal to operator) Avoid equality comparison between signed and unsigned values.

Observe the program Output The true expression 3>2 yields: 1 int main() { cout << "The true expression 3 > 2 yields: " << (3 > 2) << endl; cout << "The false expression 20 < 10 yields: "<< (20 < 10) ; return 0; } Output The true expression 3>2 yields: 1 The false expression 20<10 yields : 0

Observe this program int main() { int x; cin >> x; if (x=5) cout <<”Hello”<<endl; else cout << “Good Bye”<<endl; return 0; }

What will be the output, if..... Case 1 Case 2 x=5 x=7 The output will be Hello The output will be Hello Can you tell why?

Reason C++ considers 0 as a false and any non-zero value as true. x=5 will always evaluate to 5 as the operator used is assignment operator. 5 being a true value the code will always display 'Hello' x==5 will compare value of x with 5 and evaluate to true or false.

LOGICAL OPERATORS

Logical Operators C++ provides three logical operators to combine existing expressions. Logical OR : Represented by || symbol. Logical AND : Represented by && symbol. Logical NOT : Represented by ! symbol.

Logical OR The logical OR is binary operator that takes two expressions to connect. It is evaluated using following truth table. EXP 1 EXP 2 RESULT F T E.g. (5 > 3) || ( 8 < 3) T || F T

Logical AND The logical AND is binary operator that takes two expressions to connect. It is evaluated using following truth table. EXP 1 EXP 2 RESULT F T E.g. (5 > 3) && ( 8 < 3) T && F F

Logical NOT The logical NOT is unary operator that takes one expressions to negate it. It is evaluated using following truth table. EXP 1 RESULT F T E.g. !(5 > 3) ! T F

CONDITIONAL OPERATOR (? :) Only ternary operator of c++ language. It is written as follows, Exp1 ? Exp2 : Exp3 If expression1 evaluates to True then the whole expression evaluates to expression 2 else the whole expression evaluates to expression 3.

Consider following code snippet char grade; int marks; grade = marks >= 500 ? 'P' : 'F'; cout << grade; Output will be P if marks are greater than or equal to 500 F if marks are not greater than or equal to 500

Consider following code snippet int x,y; float value; cin >> value; value > 500 ? x : y =10; ! NOTE : Conditional operator is allowed on the left side of an expression. x will be 10 if value is greater than 500, else y will be 10.

Some Other Operators sizeof ( ) : This is compile time operator that evaluates to number of bytes occupied by variable or date type specified in parenthesis. E.g. cout << sizeof(char); Will display 1 E.g. char ch; cout << sizeof(ch); Will display 1

COMMA OPERATOR It is used to string together several expressions. It is evaluated from left to right. E.g. b=(a=3,a+1); First a get value 3 then b gets value a+1.

CHECK POINT SOLVE WORKSHEET 2 TO SEE IF YOU HAVE UNDERSTOOD WHAT WE HAVE DONE TILL NOW.

PRECEDENCE OF OPERATORS HIGHEST ++ (Post increment), -- (Post decrement) ++ (Pre increment), -- (Pre decrement), !, +(unary plus), - (unary minus), sizeof *(multiply), / (divide), % (modulus) +(add), - (subtract) < (less than), >(greater than), <=(less than or equal to), >=(greater than or equal to) == (equal), != (not equal) && (l)ogical AND) || (logical OR) ? : (Conditional Operator) = (assignment) LOWEST , (Comma operator)

Expression Evaluation Let us see how the expressions get evaluated. F = ++A / B - A A = 5, B = 2 F = ++A / B - A A = 6, B = 2 F = 6 / B - A A = 6, B = 2 A = 6, B = 2 F = 6 / 2 - A A = 6, B = 2 F = 3 - A A = 6, B = 2 F = 3 - 6 A = 6, B = 2 F = -3 ! NOTE : When more than one operator of same predecence is there evaluation is done from left to right.

Expression Evaluation Let us see how the expressions get evaluated. F = A ++ / B - A A = 5, B = 2 F = A++ / B - A A = 5, B = 2 F = 5 / B - A A = 6, B = 2 A = 6, B = 2 F = 5 / 2 - A A = 6, B = 2 F = 2.5 - A A = 6, B = 2 F = 2.5 - 6 A = 6, B = 2 F = -3.5 ! NOTE : When more than one operator of same predecence is there evaluation is done from left to right.

CHECK POINT SEE IF YOU CAN EVALUATE EXPRESSIONS BY USING CORRECT PRECEDENCE OF OPERATOR. TRY AND SOLVE WORKSHEET 3

Expressions An expression in C++ is any series of tokens that, when it is evaluated and all commands contained within it are run, is equivalent to a value. For instance, a + b is an expression, as are 35902 and "Hello world!". An expression is said to “evaluate to” its value. This is in contrast to a statement, such as x = a + b;, which gives an instruction to the processor.

TYPES OF EXPRESSION # Arithmatic expressions. # Logical expressions # Expressions with explicit type conversions. # Expression with implicit type conversions.

CHECK POINT TRY AND SEE IF YOU CAN IDENTIFY EXPRESSIONS. SOLVE WORKSHEET 4

Parts of Expression There are two different parts of expressions: L-values : An L-value appears on the left side of an assignment statement (“L” for “left”); it is the thing that is assigned to. R-values : An R-value is the expression whose value is evaluated, and possibly assigned to an L-value. For example, in the statement x = y + 5;, x and y are both identifiers; x is an L-value; and y, 5, and y + 5 are all R-values.

Valid Expressions a/b 2 * x + y sqrt(b *a) log(2) *3 3 % 2 p / q * r - t e >= g (x>y) && (y>z) These are examples of valid expressions.

Invalid Expressions a/ *b 2x + y sqrt(-a) log(-2) *3 3.5 % 2 These are examples of invalid expressions.

Some Mathematical Functions to write expressions Prototype Description ceil double ceil( double) Returns smallest integer not less than parameter. exp double exp(double) Return the logarithmic e to the arg power. pow double pow(double base, double exp) Returns base raise to exp sin double sin (double arg) Returns sine of arg, where arg is angle in radian. Include math.h header file if you are going to use any of these functions.

Some Mathematical Functions to write expressions Prototype Description cos double cos( double arg) Returns cos of arg, where arg is angle in radian. tan double tan(double arg) Returns tan of arg, where arg is angle in radian. fabs double fabs(double num) Returns absolute value of num log double log (double num) Returns natural logarithm of the num Include math.h header file if you are going to use any of these functions.

TYPE CONVERSION The conversion of one predefined type to another is called type conversion. There are two types of conversion Implicit Type Conversion Explicit Type Conversion (Type Casting)

Type Conversion Hierarchy HIGHEST Long double double float Unsigned long int long Unsigned int LOWEST int This means that if an expression is have different types of operands then the resultant operand would have type that is higher in hierarchy.

TYPE CONVERSION E.g. Take following example 2 + 3.14 One operand is of int type and other is float. As float is higher up in hierarchy the resultant type will be float. The result will be 5.14

Explicit Type Conversion Explicit conversion is user-defined. That forces the expression to be of specific type. It is also called type casting. E.g. (float)(x+y/2) This will force the result to be floating point value

C++ SHORTHANDS C++ offers special shorthands that simplify coding. Normal Expression Shorthand Expression X = X + 10 X += 10 X = X - 10 X -= 10 X = X * 10 X *= 10 X = X / 10 X /= 10 X = X % 10 X %= 10

Evaluate your understanding of the chapter by solving Worksheet 5. CHECK POINT Evaluate your understanding of the chapter by solving Worksheet 5.