Oop Exp2

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 17

Experiment No.

. Aim: WAP to print the grade for an input test score: using the if-else ladder

• Percentage • Grade

• 0-60 • F

• 61-70 • D

• 71-80 • C

• 81-90 • B

• 91-100 • A

b. Switch-case: menu driven calculator.

c. WAP to find whether the entered number is Armstrong no or not.

Theory:

Java supports two types of castings – primitive data type casting and reference type casting.
Reference type casting is nothing but assigning one Java object to another object. It comes with
very strict rules.
Java data type casting comes with 3 flavors.
1. Implicit casting
2. Explicit casting
3. Boolean casting.
1. Implicit casting (widening conversion)
A data type of lower size (occupying less memory) is assigned to a data type of higher size. This
is done implicitly by the JVM. The lower size is widened to higher size. This is also named
as automatic type conversion.
Examples:

int x=10; //occupies 4 bytes

double y=x; // occupies 4

bytes System.out.println(y); // Prints

In the above code 4 bytes integer value is assigned to 8 bytes double value.

2. Explicit casting (narrowing conversion)

A data type of higher size (occupying more memory) cannot be assigned to a data type of
lower size. This is not done implicitly by the JVM and requires explicit casting; a casting
operation to be performed by the programmer. The higher size is narrowed to lower size.

double x=10.5; //occupies 4 bytes


10.0
int y=x; // occupies 4 bytes; raises compilation error.

n the above code, 8 bytes double value is narrowed to 4 bytes int value. It raises error. Let us
explicitly type cast it.

double x=10.5; //occupies 4

bytes int y= (int) x;

The double x is explicitly converted to int y. The thumb rule is, on both sides, the same data type
should exist.

Produce results of type


boolean Comparisons use 9
operators:
Equal == Not equal !=
Less than < Less than or equal <=
Greater than > Greater than or equal
>= Logical and && Logical or ||
Assignment is not the same as equality
= is not the same as ==
Assignment places right hand side into left hand side
• Assignments are expressions:
int x, y;
x= y= 5; // Same as x = (y= 5); associate from
R to L T
hree methods of processing a program:
 In sequence
 Œ Branching
 Œ Looping

Œ Branch: Altering the flow of program execution by making a selection or

choice. Œ Loop: Altering the flow of program execution by repeating statements.

Java has very flexible three looping mechanisms. You can use one of the following three loops:

 while Loop
 do...while Loop
 for Loop
Java provides a rich set of operators to manipulate variables. We can divide all the Java
operators into the following groups:

 Arithmetic Operators

 Relational Operators

SIES GRADUATE SCHOOL OF TECHNOLOGY Page 19


 Bitwise Operators

 Logical Operators

 Assignment Operators

 Increment and Decrement Operator

 Conditional Operator

 Special Operator

TheBitwiseOperators:

Java defines several bitwise operators, which can be applied to the integer types, long, int,
short, char, and byte.

Bitwise operator works on bits and performs bit-by-bit operation. Assume if a = 60; and b =
13; now in binary format they will be as follows:
a = 0011 1100

b = 0000 1101

a&b = 0000 1100

a|b = 0011 1101

a^b = 0011 0001

~a = 1100 0011

The following table lists the bitwise operators:

SR.NO Operator and Description

1 & (bitwise and)


Binary AND Operator copies a bit to the result if it exists in both operands.
Example: (A & B) will give 12 which is 0000 1100

2 | (bitwise or)
Binary OR Operator copies a bit if it exists in either operand.
Example: (A | B) will give 61 which is 0011 1101

3 ^ (bitwise XOR)
Binary XOR Operator copies the bit if it is set in one operand but not both.
Example: (A ^ B) will give 49 which is 0011 0001
SIES GRADUATE SCHOOL OF TECHNOLOGY Page 20
4 ~ (bitwise compliment)
Binary Ones Complement Operator is unary and has the effect of 'flipping'
bits.
Example: (~A ) will give -61 which is 1100 0011 in 2's complement form
due to a signed binary number.

5 << (left shift)


Binary Left Shift Operator. The left operands value is moved left by the
number of bits specified by the right operand
Example: A << 2 will give 240 which is 1111 0000

6 >> (right shift)


Binary Right Shift Operator. The left operands value is moved right by the
number of bits specified by the right operand.
Example: A >> 2 will give 15 which is 1111

7 >>> (zero fill right shift)


Shift right zero fill operator. The left operands value is moved right by the
number of bits specified by the right operand and shifted values are filled
up with zeros.
Example: A >>>2 will give 15 which is 0000 1111

Switch-case: menu driven

calculator. Program logic :

In addition to the nested if statement, Java provides a second method for choosing from many
alternative actions. Compare the following code, each of which accomplishes the same task.
The default case, at the end of the swtich statement, acts similarly to the else at the end of the
nested if. It will catch any value that doesn't have an exact match in the cases. Although it is not
necessary to include the default case (just as it is not necessary to include the else), it is good
programming practise to account for any unexpected values.
One of the significant limitations of the switch statement is the expression that can be used to
control it. With an if statement, anything can be compared to produce an true or false result
(e.g., primitive data such as int or float, more complex data such as Strings, or even objects
created by the user).
In a switch statement, however, the expression controlling the switch must have an integer
representation, which limits it to the following data types: byte, short, int, long, or char.

Example :
switch (score)
{
case 1:
grade = 'A';
break;
case 2:
grade =
'B';
SIES GRADUATE SCHOOL OF TECHNOLOGY Page 21
break;
case 3:
grade =
'C';
break;
default:
System.out.println("Invalid score – grade of ? assigned");
grade = '?';
break;

WAP to generate the prime numbers between 1-

100. Program logic :

With this example we are going to demonstrate how to generate prime numbers with a simple
for loop. A prime number is a number that has no positive divisors other than 1 and itself. In
short, to generate a prime number using a for loop you should:

▪ Create a for statement with an int i variable from 1 to a max int number, and step equal
to 1.
▪ For each one of the numbers in the loop create a boolean isPrimeNumber equal to
true and create another loop where the number is divided to other numbers from 2
up to the number, and if the result is zero, then the boolean isPrimeNumber is set to
false.

WAP to find whether the given number is Armstrong or not.

Program logic :

Armstrong number c program: c programming code to check whether a number


is armstrong or not. A number is armstrong if the sum of cubes of individual
digits of anumber is equal to the number itself. For example 371 is an armstrong
number as 33+ 73 +13 = 371. Some other armstrong numbers are: 0, 1, 153, 370,
407.

Conclusion: Thus we have implemented basic java programs and studied basic
syntax of Java programming language.
a. WAP to print the grade for an input test score: using the if-else ladder.
Percentage Grade

1. 0-60 - E
2. 61-70 - D
3. 71-80 - C
4. 81-90 - B
5. 91-100 – A

import java.util.*;

class grade

public static void main(String args[])

Scanner sc=new Scanner(System.in);

System.out.println("Enter marks of English, Maths, Physics, Chemistry and Biology= ");

int e=sc.nextInt();

int m=sc.nextInt();

int p=sc.nextInt();
int c=sc.nextInt();

int b=sc.nextInt();

int avg=(e+m+p+c+b)/5;

if(avg>90)

System.out.println("A Grade");

else if(avg<91&&avg>80)

System.out.println("B Grade");

else if(avg<81&&avg>70)

System.out.println("C Grade");

else if(avg<71&&avg>60)

System.out.println("D Grade");

else

System.out.println("E Grade");

}
OUTPUT:
b. Switch-case: menu driven calculator.

import java.util.*;

class calculator

public static void main(String args[])

int z=0;

double d=0.0;

Scanner sc=new Scanner(System.in);

System.out.println("enter two numbers= ");

double a=sc.nextDouble();

double b=sc.nextDouble();

do

System.out.println("1.Addition");

System.out.println("2.Subtraction");

System.out.println("3.Multiplication");

System.out.println("4.Division");

System.out.println("\nenter choice= ");

int c=sc.nextInt();

switch(c)

case 1:

{
d=a+b;

System.out.println("Addition="+d);

break;

case 2:

d=a-b;

System.out.println("Subraction="+d);

break;

case 3:

d=a*b;

System.out.println("Multiplication="+d);

break;

case 4:

d=a/b;

System.out.println("Division="+d);

break;

default:

System.out.println("Invalid Choice");
}

System.out.println("Press 1 to continue");

z=sc.nextInt();

while(z==1);

OUTPUT:
c. WAP to find whether the entered number is Armstrong no or not.

import java.util.*;

class armstrong

public static void main(String args[])

double r=0.0;

double sum=0.0;

int count=0;

Scanner sc=new Scanner(System.in);

System.out.println("Enter a number= ");

int n=sc.nextInt();

int a=n;

int b=n;

while(a!=0)

count++;

a=a/10;

}
while(b!=0)

r=b%10;

sum=sum+Math.pow(r,count);

b=b/10;

if(sum==n)

System.out.println("Armstrong number");

else

System.out.println("Not an Armstrong number");

OUTPUT:
Conclusion: Through this program we have studied and implemented the use of control
statements

You might also like