Tasks studies - laboratory
What will the following program return? Justify your answer.
public class IncDec {
public static void main(String[] arg) {
double a = 12.12;
System.out.println(a--);
System.out.println(a++);
System.out.println(--a);
System.out.println(++a);
}
}
Write a program demonstrating the use of logical operators &&
(AND) and ||
(OR). Use an if
conditional structure.
Task 2.2 What are the differences between the following operators:
&&
vs &
||
vs |
Study the following article: LINK
Then write programs demonstrating the behavior of the following operators:
<<
>>
>>>
Consider the following code fragment:
int a = 17;
double b = 4.0;
a += b; // ?
a -= b; // ?
a *= b; // ?
a /= b; // ?
a %= b; // ?
What arithmetic operations do these expressions represent, and what results will they return?
Consider the following code fragment:
int a = 5;
int b = 3;
int c = a + b++;
int d = (a++) + b;
In what order will the operations be performed during the computation of variables c
and d
? What values will be calculated?
What operators in Java define logical operations NOT
and XOR
? Create appropriate programs demonstrating their behavior as logic gates.
Create a program using an operator opposite to the comparison operator ==
.
Familiarize yourself with the documentation of the String
class:
LINK
Test the following program:
public class StringExample {
public static void main(String args[]) {
String s1 = new String("Happy ");
String s2 = new String("Birthday");
System.out.printf("s1 = %s\ns2 = %s\n\n", s1, s2);
System.out.printf("Result of s1.concat(s2) = %s\n", s1.concat(s2));
System.out.printf("s1 after concatenation = %s\n", s1);
}
}
Describe the functionality of the following String
class methods in words and create simple Java applications to demonstrate their operation—use the above program as a template. Display the results on the console.
char[] toCharArray()
byte[] getBytes()
boolean equals(String str)
boolean equalsIgnoreCase(String str)
int compareTo(String str)
int compareToIgnoreCase(String str)
int indexOf(int i)
int indexOf(String str)
int lastIndexOf(int i)
int lastIndexOf(String str)
String substring(int startString)
String substring(int startString, int stopString)
String replace(char original, char replacement)
String trim()
String toLowerCase()
String toUpperCase()
String[] split(String regex, int limit)
String[] split(String regex)
Test the following program:
import java.util.*;
public class Factorial {
// The factorial method returns the factorial of a number passed as a parameter
// Factorial computation is performed using recursion
public static int factorial(int value) {
// If the passed parameter equals zero, return 1
// Otherwise, return the parameter value * factorial of (parameter - 1)
if (value == 0) return 1;
else return value * factorial(value - 1);
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("Enter a number: ");
// User inputs a number
int number = sc.nextInt();
// Display the calculated factorial
System.out.println(number + "! = " + factorial(number));
}
}
When the application is executed:
Analysis:
Entering the number 5 as input will call the factorial
method with the value 5. The method will return the parameter value multiplied by another call to the factorial
method with the parameter decremented by 1, and so on.
The process will look as follows:
Create a program to calculate factorial without using recursion. Use any type of loop to perform the operation.
Implement the exponentiation algorithm in two versions: recursive and iterative (as two separate methods). To complete the task, refer to the following material:
LINK
Implement an algorithm to calculate the Fibonacci sequence. To complete the task, refer to the following material:
LINK
(optional)
Write an algorithm to solve the Towers of Hanoi problem.
To complete the task, refer to the following material:
LINK