Assignment, equality comparison problem – Computer Sir Ki Class

Login


Lost your password?

Don't have an account ?
Register (It's FREE) ×
  

Login
[lwa]



Solved Problem #CPP#2314 siteicon   siteicon   siteicon  

Problem Statement - Assignment, equality comparison problem

Find the output of the program given below. Assume all relevant header files are included

int main( )
{
  int a,b,c=101,d=102;
  a=(c=d);
  cout<<a<<endl;
  b=(c==d);
  cout<<b<<endl;
  return 0 ;
}

Solution

TC++ #2314

 

Run Output

102
1

Notes

int a,b,c=101,d=102;
Here a and b do not have initial values and c and d have values 101 and 102 respectively.

a=(c=d);
Here left hand side inside will be evaluated first where the value of d is assigned to c. So c will leave its original value and will be assigned the value of d which is 102. So from left hand side c will contain 102. Finally with the last assignment operation a will contain the new value of c which will be 102.

cout<<a<<endl;
This will print 102 as explained above.

b=(c==d);
Here the operator inside bracket on the right hand side is the comparison operator for equality check. Since c has already be assigned 102 in the previous operation, so it will become equal to d which was originally set for 102. Which means that comparison operation will return true status. In c++ if comparison evaluates to true, it is stored as 1 if equated to an integer storage. So b will be 1.

cout<<b<<endl;
This will print 1 as explained above.

Common Errors

  • The modification of value of c to value of d in first expression is often missed by students.
  • The watch over difference between = and == operator is essential for this kind of programs.


Share

sunmitra| Created: 6-Jan-2018 | Updated: 18-Dec-2018|






×
Introductory Sessions Beginning to Program Tokens Keyword and Identifiers Data Types Variables and Constants Operators Simple User Input Building Expressions and Formulas Simple Real World Problems Simple If and If Else Multiple-Nested-Ladder of If Else Switch case selection Simple Loops Tricks in Loops - break continue scope Loop Applications - Handling numerals Series printing loops Nested Loops Pattern printing loops Number Varieties and Crunches String Handling (Null Terminated) Strings - string class type Functions (Built-in) Functions - user defined Functions Reference Passing/Returning Arrays Concepts and 1-D Arrays Array Data Management Two dimensional arrays and Matrices Structures Basics Structures passing/returning 2D Array Memory Addressing Display Using IO Manipulation Display Using C Formatting Tricks User Defined Data Types Enumerated Types Preprocessor Directives And Macros Exception Handling Programming Paradigms and OOPs Advantages Abstraction and Encapsulation Polymorphism Inheritance Function Overloading Concepts Function Overloading Varieties Function Overloading Special Cases Defining Classes Creating and Using Class Objects Class Members Accessibility Class Function Types Inline Functions Constant Functions Nesting of Functions Class Members Scope Resolution Static Members in a Class Array of Objects Constructor Concepts Default Constructor Parameterized Constructor Copy Constructor Constructor Overloading Destructors Inheritance Fundamentals Public Derivations Private and Protected Derivations Multiple Inheritance Multi-Level Inheritance Class Nesting Data File Concepts Handling Text Files Handling Binary Files Pointer Concepts Pointer and Arrays Pointers and Functions Object Pointers This Pointer Linked Lists Stacks Queues


Back