mirror of
https://github.com/ASDjonok/OOP_IO-2x_2023.git
synced 2026-04-01 21:21:50 +03:00
Compare commits
7 Commits
ІО-24/01-Б
...
ІО-24/12-З
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2874cce9b6 | ||
|
|
0ec39254b8 | ||
|
|
d7edabbf00 | ||
|
|
71b6763c9d | ||
|
|
33f8aa39e1 | ||
|
|
f70028323e | ||
|
|
bcb73f3a13 |
2
.idea/misc.xml
generated
2
.idea/misc.xml
generated
@@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project version="4">
|
<project version="4">
|
||||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-18" project-jdk-type="JavaSDK">
|
<component name="ProjectRootManager" version="2" languageLevel="JDK_18" default="true" project-jdk-name="openjdk-18" project-jdk-type="JavaSDK">
|
||||||
<output url="file://$PROJECT_DIR$/out" />
|
<output url="file://$PROJECT_DIR$/out" />
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
||||||
@@ -1,140 +0,0 @@
|
|||||||
package Lab1;
|
|
||||||
|
|
||||||
import java.util.InputMismatchException;
|
|
||||||
import java.util.Scanner;
|
|
||||||
|
|
||||||
public class Lab1 {
|
|
||||||
public static void main(String[] args) {
|
|
||||||
int C2, C3, C5, C7; // creating variables
|
|
||||||
int numBook = 2401; // default value of scorebook
|
|
||||||
|
|
||||||
Scanner sc = new Scanner(System.in); // scanner creating for inputing values from keyboard
|
|
||||||
System.out.println("By default number of scorebook is 2401. \nEnter to skip or input new value: ");
|
|
||||||
String input = sc.nextLine();
|
|
||||||
|
|
||||||
if (!input.equals("")) { // try-catch for checking correct inputing of value
|
|
||||||
try {
|
|
||||||
numBook = Math.abs(Integer.parseInt(input)); // scorebook can be only unsigned
|
|
||||||
} catch (NumberFormatException e) {
|
|
||||||
System.out.println("Invalid input. Using default value 2401"); // printing that will be used default value
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
String[] operations1 = {"+", "-"};//
|
|
||||||
String[] operations2 = {"*", "/", "%", "+", "-"}; // String array for choosing operations
|
|
||||||
String[] operations3 = {"byte", "short", "int", "long", "char", "float", "double"}; //
|
|
||||||
// determining variables
|
|
||||||
C2 = numBook % 2;
|
|
||||||
C3 = numBook % 3;
|
|
||||||
C5 = numBook % 5;
|
|
||||||
C7 = numBook % 7;
|
|
||||||
|
|
||||||
String O1 = operations1[C2];
|
|
||||||
int C = C3;
|
|
||||||
String O2 = operations2[C5];
|
|
||||||
String O3 = operations3[C7];
|
|
||||||
|
|
||||||
System.out.println("C2 is: " + C2 + ", operation is: " + O1); //
|
|
||||||
System.out.println("C3 is: " + C); // printing parameters that user got
|
|
||||||
System.out.println("C5 is: " + C5 + ", operation is: " + O2); //
|
|
||||||
System.out.println("C7 is: " + C7 + ", Type of indexes i and j is: " + O3); //
|
|
||||||
|
|
||||||
Number i = 0; // creating objects i j of (abstract)superclass Number
|
|
||||||
Number j = 0; //
|
|
||||||
|
|
||||||
|
|
||||||
System.out.println("\nEnter a value for i and j in the " + O3 + " type: ");
|
|
||||||
|
|
||||||
switch (O3) { // Choosing type of i and j by C7
|
|
||||||
case "byte" -> {
|
|
||||||
try {
|
|
||||||
i = sc.nextByte();
|
|
||||||
j = sc.nextByte();
|
|
||||||
} catch (InputMismatchException e) {
|
|
||||||
System.out.println("Invalid input. Please enter a valid byte value.");
|
|
||||||
sc.nextLine();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
case "short" -> {
|
|
||||||
i = sc.nextShort();
|
|
||||||
j = sc.nextShort();
|
|
||||||
}
|
|
||||||
case "int" -> {
|
|
||||||
i = sc.nextInt();
|
|
||||||
j = sc.nextInt();
|
|
||||||
}
|
|
||||||
case "long" -> {
|
|
||||||
i = sc.nextLong();
|
|
||||||
j = sc.nextLong();
|
|
||||||
}
|
|
||||||
case "char" -> {
|
|
||||||
System.out.println("Read only first character!");
|
|
||||||
i = (int) sc.next().charAt(0);
|
|
||||||
j = (int) sc.next().charAt(0);
|
|
||||||
}
|
|
||||||
case "float" -> {
|
|
||||||
i = sc.nextFloat();
|
|
||||||
j = sc.nextFloat();
|
|
||||||
}
|
|
||||||
case "double" -> {
|
|
||||||
i = sc.nextDouble();
|
|
||||||
j = sc.nextDouble();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
System.out.println("The value of the created variables is: " + i + " and " + j);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class Sum { // creating class Sum
|
|
||||||
int n, m;
|
|
||||||
double i, j;
|
|
||||||
|
|
||||||
public Sum(double i, double j, int n, int m) { // Constructor to initialize all variables
|
|
||||||
this.i = i;
|
|
||||||
this.j = j;
|
|
||||||
this.n = n;
|
|
||||||
this.m = m;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void calc() { // create method for our class
|
|
||||||
double sum = 0, result = 0, result2 = 0;
|
|
||||||
if ((O1.equals("-") && i + n >= C && i <= C) || (C == 0 && i == 0)) { // exclude situations
|
|
||||||
System.out.println("dividing by zero!"); // with dividing by 0
|
|
||||||
} else if (i > n || j > m) {
|
|
||||||
System.out.println("i or j greater than n or m");
|
|
||||||
} else {
|
|
||||||
for (double b = i; b <= n; b++) {
|
|
||||||
for (double a = j; a <= m; a++) {
|
|
||||||
switch (O2) {
|
|
||||||
case "+" -> result = b + a;
|
|
||||||
case "-" -> result = b - a;
|
|
||||||
case "*" -> result = b * a;
|
|
||||||
case "/" -> result = b / a;
|
|
||||||
case "%" -> result = b % a;
|
|
||||||
}
|
|
||||||
switch (O1) {
|
|
||||||
case "+" -> result2 = b + C;
|
|
||||||
case "-" -> result2 = b - C;
|
|
||||||
}
|
|
||||||
sum += result / result2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
System.out.println("Sum is: " + sum);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
System.out.print("Enter value for n and m: \n");
|
|
||||||
|
|
||||||
int n = sc.nextInt();
|
|
||||||
int m = sc.nextInt();
|
|
||||||
|
|
||||||
Sum sum = new Sum(i.doubleValue(), j.doubleValue(), n, m); // creating new instance of Sum class
|
|
||||||
// .doubleValue() converting our variables to double
|
|
||||||
sum.calc();
|
|
||||||
sc.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,153 +0,0 @@
|
|||||||
package Lab2;
|
|
||||||
|
|
||||||
import java.util.Scanner;
|
|
||||||
import java.util.Random;
|
|
||||||
|
|
||||||
public class Lab2 {
|
|
||||||
public static void main(String[] args) {
|
|
||||||
final int C5, C7, C11, NumBook;
|
|
||||||
NumBook = 2401;
|
|
||||||
C5 = NumBook % 5;
|
|
||||||
C7 = NumBook % 7;
|
|
||||||
C11 = NumBook % 11;
|
|
||||||
System.out.println("-----------------------------------------------------");
|
|
||||||
System.out.println("C5 is: " + C5 + " - act with martix is C=Bт");
|
|
||||||
System.out.println("C7 is: " + C7 + " - type of elements is double");
|
|
||||||
System.out.println("C11 is: " + C11 + " - calculate the sum of the largest elements\n" +
|
|
||||||
"of each row of the matrix");
|
|
||||||
System.out.println("-----------------------------------------------------");
|
|
||||||
int Mside = 0;
|
|
||||||
int Nside = 0;
|
|
||||||
int Choose;
|
|
||||||
double MaxSum = 0;
|
|
||||||
Random rand = new Random();
|
|
||||||
Scanner sc = new Scanner(System.in);
|
|
||||||
|
|
||||||
while (true) {
|
|
||||||
try {
|
|
||||||
System.out.print("Enter random or handle input(1 or 0): ");
|
|
||||||
Choose = Math.abs(Integer.parseInt(sc.nextLine()));
|
|
||||||
if (Choose == 1 || Choose == 0) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} catch (NumberFormatException e) {
|
|
||||||
System.out.println("Invalid input. Please enter an integer.");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
while (true) {
|
|
||||||
try {
|
|
||||||
System.out.print("Enter number of rows: ");
|
|
||||||
Mside = Math.abs(Integer.parseInt(sc.nextLine()));
|
|
||||||
if (Mside <= 0) {
|
|
||||||
System.out.println("Invalid input. Number of rows must be greater than 0");
|
|
||||||
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} catch (NumberFormatException e) {
|
|
||||||
System.out.println("Invalid input. Please enter an integer.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
while (true) {
|
|
||||||
try {
|
|
||||||
System.out.print("Enter number of columns: ");
|
|
||||||
Nside = Math.abs(Integer.parseInt(sc.nextLine()));
|
|
||||||
if (Nside <= 0) {
|
|
||||||
System.out.println("Invalid input. Number of columns must be greater than 0");
|
|
||||||
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} catch (NumberFormatException e) {
|
|
||||||
System.out.println("Invalid input. Please enter an integer.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
final int lenghtMaxElements = 5;
|
|
||||||
double[][] CArray = new double[Mside][Nside];
|
|
||||||
double[][] TransposedArray = new double[Nside][Mside];
|
|
||||||
double[][] MaxElements = new double[Nside][lenghtMaxElements];
|
|
||||||
if (Choose == 1) {
|
|
||||||
for (int i = 0; i < Mside; i++) {
|
|
||||||
for (int j = 0; j < Nside; j++) {
|
|
||||||
CArray[i][j] = rand.nextDouble(-100, 100);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (Choose == 0) {
|
|
||||||
for (int i = 0; i < Mside; i++) {
|
|
||||||
for (int j = 0; j < Nside; j++) {
|
|
||||||
while (true) {
|
|
||||||
try {
|
|
||||||
System.out.printf("Enter the element at position (%d,%d): ", i + 1, j + 1);
|
|
||||||
CArray[i][j] = Double.parseDouble(sc.nextLine());
|
|
||||||
break;
|
|
||||||
} catch (NumberFormatException e) {
|
|
||||||
System.out.println("Invalid input. Please enter a valid number.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (int i = 0; i < Mside; i++) {
|
|
||||||
for (int j = 0; j < Nside; j++) {
|
|
||||||
System.out.printf("%8.2f", CArray[i][j]);
|
|
||||||
}
|
|
||||||
System.out.println();
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i = 0; i < Nside; i++) {
|
|
||||||
for (int j = 0; j < Mside; j++) {
|
|
||||||
TransposedArray[i][j] = CArray[j][i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
System.out.println("Transposed array is:");
|
|
||||||
int row, cols;
|
|
||||||
for (row = 0; row < Nside; row++) {
|
|
||||||
for (cols = 0; cols < Mside; cols++) {
|
|
||||||
System.out.printf("%8.2f", TransposedArray[row][cols]);
|
|
||||||
|
|
||||||
}
|
|
||||||
System.out.println();
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i = 0; i < Nside; i++) {
|
|
||||||
MaxElements[i][0] = TransposedArray[i][0];
|
|
||||||
|
|
||||||
for (int j = 1; j < Mside; j++) {
|
|
||||||
MaxElements[i][1] = i;
|
|
||||||
if (TransposedArray[i][j] > MaxElements[i][0]) {
|
|
||||||
MaxElements[i][0] = TransposedArray[i][j];
|
|
||||||
MaxElements[i][2] = j;
|
|
||||||
|
|
||||||
|
|
||||||
} else if (TransposedArray[i][j] == MaxElements[i][0]) {
|
|
||||||
MaxElements[i][3] = MaxElements[i][0];
|
|
||||||
MaxElements[i][4] = 1;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
//System.out.println(MaxElements[i][0] +" "+ MaxElements[i][1] +" "+ MaxElements[i][2] + " " + MaxElements[i][3] + " " + MaxElements[i][4]);
|
|
||||||
//code i used for debug
|
|
||||||
}
|
|
||||||
System.out.println("Max elements for each row:");
|
|
||||||
if (Mside == 1) {
|
|
||||||
System.out.println("I can`t find max element for mx1 matrix");
|
|
||||||
|
|
||||||
} else {
|
|
||||||
for (int i = 0; i < Nside; i++) {
|
|
||||||
if (MaxElements[i][0] == MaxElements[i][3] && MaxElements[i][4] == 1) {
|
|
||||||
System.out.printf("In row %1.0f does not exist a max element\n", MaxElements[i][1] + 1);
|
|
||||||
} else {
|
|
||||||
System.out.printf("%8.2f is max value and his coordinate: (%1.0f, %1.0f)\n", MaxElements[i][0], MaxElements[i][1] + 1, MaxElements[i][2] + 1);
|
|
||||||
MaxSum += MaxElements[i][0];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
System.out.printf("Sum of elements with max values is: %.2f\n", MaxSum);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,73 +0,0 @@
|
|||||||
package Lab3;
|
|
||||||
|
|
||||||
import java.util.Scanner;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Collections;
|
|
||||||
|
|
||||||
public class Lab3 {
|
|
||||||
public static void main(String[] args) {
|
|
||||||
System.out.println("Введіть текст:");
|
|
||||||
Scanner scan = new Scanner(System.in); // Створюємо об'єкт Scanner для зчитування введеного тексту з консолі
|
|
||||||
String inputText = scan.nextLine(); // Зчитуємо введений текст користувача
|
|
||||||
StringBuffer textBuffer = new StringBuffer(inputText); // Створюємо відподні об'єкти StringBuffer
|
|
||||||
StringBuffer result = new StringBuffer();
|
|
||||||
|
|
||||||
while (!textBuffer.isEmpty()) { // Починаємо цикл, який виконується, доки об'єкт textBuffer не стане порожнім
|
|
||||||
|
|
||||||
int index1 = textBuffer.indexOf("."); // Знаходимо індекси для символів, які закінчують речення
|
|
||||||
int index2 = textBuffer.indexOf("!");
|
|
||||||
int index3 = textBuffer.indexOf("?");
|
|
||||||
int index4 = textBuffer.indexOf("...");
|
|
||||||
|
|
||||||
int[] SplitIndexArray = {index1, index2, index3, index4};
|
|
||||||
ArrayList<Integer> list = new ArrayList<>();
|
|
||||||
|
|
||||||
for (int j : SplitIndexArray) { // Перебираємо кожну позицію з масиву
|
|
||||||
if (j >= 0) { // Якщо символ не стоїть перед реченням, додаємо його
|
|
||||||
list.add(j);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
int min = Collections.min(list); // Знаходимо мінімальну позицію, щоб працювати з першим реченням
|
|
||||||
String sentenceString = textBuffer.substring(0, min); // Виділяємо перше речення до знайденого розділового знаку
|
|
||||||
StringBuffer sentence = new StringBuffer(sentenceString); // Створюємо об'єкт StringBuffer для речення з пробілом
|
|
||||||
|
|
||||||
if (sentenceString.contains(" ")) { // Перевіряємо, чи перше речення містить більше одного слова
|
|
||||||
String firstword1;
|
|
||||||
String secondword1 = textBuffer.substring(sentence.lastIndexOf(" ") + 1, sentence.length()); // Виділяємо друге слово з речення
|
|
||||||
String secondword2;
|
|
||||||
secondword2 = secondword1.substring(0, 1).toUpperCase() + secondword1.substring(1, secondword1.length()); // Першу літеру робимо великою, решту слова копіюємо
|
|
||||||
StringBuffer secondword = new StringBuffer(secondword2);
|
|
||||||
|
|
||||||
if (sentence.charAt(sentence.indexOf(" ") - 1) == ',') { // Перевіряємо, чи перед першим словом є кома
|
|
||||||
firstword1 = textBuffer.substring(0, sentence.indexOf(" ") - 1); // Виділяємо перше слово з речення
|
|
||||||
secondword.append(","); // Додаємо кому до другого слова
|
|
||||||
} else {
|
|
||||||
firstword1 = textBuffer.substring(0, sentence.indexOf(" ")); // Виділяємо перше слово з речення
|
|
||||||
}
|
|
||||||
|
|
||||||
String firstword2 = firstword1.substring(0, 1).toLowerCase() + firstword1.substring(1, firstword1.length()); // Перетворюємо першу літеру першого слова малою
|
|
||||||
StringBuffer firstword = new StringBuffer(firstword2);
|
|
||||||
|
|
||||||
firstword.insert(0, " "); // Додаємо пробіл перед першим словом
|
|
||||||
sentence.delete(0, sentence.indexOf(" ")); // Видаляємо перше слово з речення
|
|
||||||
sentence.insert(0, secondword); // Додаємо друге слово на початок речення
|
|
||||||
sentence.delete(sentence.lastIndexOf(" "), sentence.length()); // Видаляємо останнє слово з речення
|
|
||||||
sentence.append(firstword); // Додаємо перше слово в кінець речення
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
if ((index1 == index4) && (index1 == min)) { // Перевіряємо випадок, коли речення закінчується на "..."
|
|
||||||
sentence.append(textBuffer.substring(min, min + 3)); // Додаємо "..." до речення
|
|
||||||
textBuffer.delete(0, min + 4); // видаляємо з textBuffer
|
|
||||||
} else {
|
|
||||||
sentence.append(textBuffer.substring(min, min + 1)); // Додаємо '.' до речення
|
|
||||||
textBuffer.delete(0, min + 2); // видаляємо з textBuffer
|
|
||||||
}
|
|
||||||
|
|
||||||
sentence.append(" "); // Додаємо пробіл
|
|
||||||
result.append(sentence); // Додаємо речення до результату
|
|
||||||
|
|
||||||
}
|
|
||||||
System.out.println(result);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,118 +0,0 @@
|
|||||||
package Lab4;
|
|
||||||
|
|
||||||
import java.util.Comparator;
|
|
||||||
|
|
||||||
public class Airplane {
|
|
||||||
private int number; // Номер літака
|
|
||||||
private String model; // Модель літака
|
|
||||||
private String airline; // Компанія-власник
|
|
||||||
private int capacity; // Ємність для пасажирів
|
|
||||||
private double fuelCapacity; // Ємність палива
|
|
||||||
private boolean isFlying; // Стан літака: летить/в ангарі
|
|
||||||
|
|
||||||
// Конструктор класа
|
|
||||||
public Airplane(int number, String model, String airline, int capacity, double fuelCapacity) {
|
|
||||||
this.number = number;
|
|
||||||
this.model = model;
|
|
||||||
this.airline = airline;
|
|
||||||
this.capacity = capacity;
|
|
||||||
this.fuelCapacity = fuelCapacity;
|
|
||||||
this.isFlying = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Методи доступу, а саме геттери
|
|
||||||
public int getNumber() {
|
|
||||||
return number;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getModel() {
|
|
||||||
return model;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getAirline() {
|
|
||||||
return airline;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getCapacity() {
|
|
||||||
return capacity;
|
|
||||||
}
|
|
||||||
|
|
||||||
public double getFuelCapacity() {
|
|
||||||
return fuelCapacity;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isFlying() {
|
|
||||||
return isFlying;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFlying(boolean flying) {
|
|
||||||
isFlying = flying;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Метод для запускання літака
|
|
||||||
public void takeOff() {
|
|
||||||
if (isFlying) { // Перевірка, якщо літає, то його знову не запустити,
|
|
||||||
// у мому коді до цього уже є перевірка, але якщо наприклад розришяти
|
|
||||||
// для інших програм, де перевірки не буде, то воно збереже від помилки
|
|
||||||
System.out.println("The airplane is already flying.");
|
|
||||||
} else {
|
|
||||||
System.out.println("Taking off...");
|
|
||||||
// Виводимо інформацію про взліт літака, міняємо прапор на 'true'
|
|
||||||
isFlying = true;
|
|
||||||
System.out.println("Airplane " + number + " took off!");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Метод для посадки літака
|
|
||||||
public void land() {
|
|
||||||
if (!isFlying) { // та сама перевірка, тільки для посадки
|
|
||||||
System.out.println("The airplane is already on the ground.");
|
|
||||||
} else {
|
|
||||||
// садимо літак, пасажири плескають в долоні, а прапор 'false'
|
|
||||||
System.out.println("Landing...");
|
|
||||||
isFlying = false;
|
|
||||||
System.out.println("Airplane number " + number + " landed!");
|
|
||||||
System.out.println("Passengers: *claps*");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Перевизначений метод toString для виведення інформації про літак у зручному форматі
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
String flying = "In angar";
|
|
||||||
if (isFlying) {
|
|
||||||
flying = "Flying"; // друкувати стан прапора було би не естетично, тому перевіряємо 'true' - Flying
|
|
||||||
}
|
|
||||||
return String.format("%-7d | %-25s | %-10s | %-8d | %-12.1f | %-10s",
|
|
||||||
number, model, airline, capacity, fuelCapacity, flying); // використовуємо метод .format для зручного виведення
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Клас, що реалізує інтерфейс Comparator для порівняння літаків за номером
|
|
||||||
class SortByNumber implements Comparator<Airplane> {
|
|
||||||
public int compare(Airplane a, Airplane b) {
|
|
||||||
return a.getNumber() - b.getNumber();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Клас, що реалізує інтерфейс Comparator для порівняння літаків за моделлю
|
|
||||||
class SortByModel implements Comparator<Airplane> {
|
|
||||||
public int compare(Airplane a, Airplane b) {
|
|
||||||
return a.getModel().compareTo(b.getModel()); // Для типу String використовуємо метод compareTo
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Клас, що реалізує інтерфейс Comparator для порівняння літаків за ємністю
|
|
||||||
class SortByCapacity implements Comparator<Airplane> {
|
|
||||||
public int compare(Airplane a, Airplane b) {
|
|
||||||
return a.getCapacity() - b.getCapacity();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Клас, що реалізує інтерфейс Comparator для порівняння літаків за ємністю палива
|
|
||||||
class SortByFuelCapacity implements Comparator<Airplane> {
|
|
||||||
public int compare(Airplane a, Airplane b) {
|
|
||||||
return Double.compare(a.getFuelCapacity(), b.getFuelCapacity()); // Для типу double застосовуємо відповідний метод
|
|
||||||
// з абстрактного класу Double
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,101 +0,0 @@
|
|||||||
package Lab4;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Comparator;
|
|
||||||
import java.util.Scanner;
|
|
||||||
|
|
||||||
public class Lab4 {
|
|
||||||
int C11 = 2401 % 11; // 3 - Визначити клас літак, який складається як мінімум з 5-и полів.
|
|
||||||
public static void main(String[] args) {
|
|
||||||
Airplane[] airplanes = { // Створюємо масив літаків, можливості створити літак, який одразує літає неможливо,
|
|
||||||
// що логічно
|
|
||||||
new Airplane(1, "Boeing 747", "Airline 1", 20, 50000.0),
|
|
||||||
new Airplane(2, "Airbus A320", "Airline 1", 300, 3000.0),
|
|
||||||
new Airplane(3, "Embraer E190", "Airline 2", 1700, 2000.0),
|
|
||||||
new Airplane(4, "Cessna 172", "Airline 3", 400, 1500.0),
|
|
||||||
new Airplane(5, "Bombardier Global 6000", "Airline 1", 100, 800.0),
|
|
||||||
};
|
|
||||||
|
|
||||||
Scanner scanner = new Scanner(System.in); // Підключаємо Scanner
|
|
||||||
boolean quit = false;
|
|
||||||
while (!quit) { // Нескінченний цикл поки користувач не введе 'q'
|
|
||||||
|
|
||||||
System.out.print("\nEnter the field to sort by (number, model, capacity, fuelcapacity), 'fly' to fly airplane or enter 'q' to exit: ");
|
|
||||||
String input = scanner.nextLine();
|
|
||||||
// перевірка чи правильно введено слово
|
|
||||||
if (!input.equals("number") && !input.equals("model") && !input.equals("capacity") && !input.equals("fuelcapacity") && !input.equals("q") && !input.equals("fly")) {
|
|
||||||
System.out.println("Invalid field to sort by! Please enter 'number', 'model', 'capacity', 'fuelcapacity'.");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// перевірка виходу з програми
|
|
||||||
if (input.equals("q")) {
|
|
||||||
quit = true;
|
|
||||||
System.out.println("Closing program...");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// перевірка, чи користувач хоче запустити літак
|
|
||||||
if (input.equals("fly")){
|
|
||||||
buildBoard(airplanes); // виводимо таблицю літаків, через функцію buildBoard
|
|
||||||
System.out.print("Enter the airplane number to make it fly or land if it already fly: ");
|
|
||||||
int airplaneNumber = scanner.nextInt();
|
|
||||||
scanner.nextLine();
|
|
||||||
|
|
||||||
// Знаходимо вибраний літак
|
|
||||||
Airplane selectedAirplane = null;
|
|
||||||
for (Airplane airplane : airplanes) {
|
|
||||||
if (airplane.getNumber() == airplaneNumber) {
|
|
||||||
selectedAirplane = airplane;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// перевірка, якщо літає - садимо на землю, якщо в ангарі, то запускаємо в повітр'я
|
|
||||||
if (selectedAirplane != null) {
|
|
||||||
if (selectedAirplane.isFlying()) {
|
|
||||||
selectedAirplane.land(); // викликаємо метод для посадки
|
|
||||||
} else {
|
|
||||||
selectedAirplane.takeOff(); // викликаємо метод для запуску
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
System.out.println("No airplane found with the specified number.");
|
|
||||||
}
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
String field = input;
|
|
||||||
System.out.print("Enter the sort order (asc or desc): "); // вибір користувачем сортування за спаданням
|
|
||||||
String order = scanner.nextLine(); // чи зростанням
|
|
||||||
|
|
||||||
if (!order.equals("asc") && !order.equals("desc")) { // перевірка чи правильно введено символ
|
|
||||||
System.out.println("Invalid sort order! Please enter 'asc' or 'desc'.");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// "потужний" swtich
|
|
||||||
Comparator<Airplane> comparator = switch (field) { // в залежності від введеного слова - певний метод сортування
|
|
||||||
case "number" -> new SortByNumber();
|
|
||||||
case "model" -> new SortByModel();
|
|
||||||
case "capacity" -> new SortByCapacity();
|
|
||||||
case "fuelcapacity" -> new SortByFuelCapacity();
|
|
||||||
default -> null;
|
|
||||||
};
|
|
||||||
|
|
||||||
if (order.equals("desc")) { // інвертуємо для зворотнього порядку
|
|
||||||
comparator = comparator.reversed();
|
|
||||||
}
|
|
||||||
Arrays.sort(airplanes, comparator); // сортуємо літаки за результатами компоратора
|
|
||||||
|
|
||||||
System.out.println("\nSorted by " + field + " (in " + order + "ending order):");
|
|
||||||
buildBoard(airplanes); // виклик функції buildBoard
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
public static void buildBoard(Airplane[] airplanes){ // Функція нічого не повертає, приймає на вхід масив літаків
|
|
||||||
System.out.println(String.format("%n%-7s | %-25s | %-10s | %-6s | %12s | %-10s", "Number", "Model", "Airline", "Capacity", "Fuel Capcity", "Is flying"));
|
|
||||||
System.out.println("---------------------------------------------------------------------------------------");
|
|
||||||
for (Airplane airplane : airplanes) { // "потужний" цикл for, щоб зручно перебрати літаки
|
|
||||||
System.out.println(airplane.toString()); // викликаємо метод toSring(), який є прикладом поліморфізму
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,97 +0,0 @@
|
|||||||
package Lab6;
|
|
||||||
|
|
||||||
import java.util.Comparator;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Абстрактний клас Car представляє основні властивості автомобіля
|
|
||||||
* Він містить конструктор для ініціалізації властивостей автомобіля,
|
|
||||||
* а також методи доступу до цих властивостей.
|
|
||||||
*/
|
|
||||||
public abstract class Car {
|
|
||||||
private final String make; // Марка автомобіля
|
|
||||||
private final String model; // Модель автомобіля
|
|
||||||
private final int year; // Рік випуску автомобіля
|
|
||||||
private final int price; // Ціна автомобіля
|
|
||||||
private final int speed; // Швидкість автомобіля
|
|
||||||
private final double fuelConsumption;// Споживання палива автомобілем
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Конструктор класу Car ініціалізує властивості автомобіля.
|
|
||||||
*
|
|
||||||
* @param make марка автомобіля
|
|
||||||
* @param model модель автомобіля
|
|
||||||
* @param year рік випуску автомобіля
|
|
||||||
* @param price ціна автомобіля
|
|
||||||
* @param speed швидкість автомобіля
|
|
||||||
* @param fuelConsumption споживання палива автомобілем
|
|
||||||
*/
|
|
||||||
public Car(String make, String model, int year, int price, int speed, double fuelConsumption) {
|
|
||||||
this.make = make;
|
|
||||||
this.model = model;
|
|
||||||
this.year = year;
|
|
||||||
this.price = price;
|
|
||||||
this.speed = speed;
|
|
||||||
this.fuelConsumption = fuelConsumption;
|
|
||||||
}
|
|
||||||
// Звичайні геттери, тому їх сильно не розписував
|
|
||||||
public String getMake() {
|
|
||||||
return make;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getModel() {
|
|
||||||
return model;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getYear() {
|
|
||||||
return year;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getPrice() {
|
|
||||||
return price;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getSpeed() {
|
|
||||||
return speed;
|
|
||||||
}
|
|
||||||
|
|
||||||
public double getFuelConsumption() {
|
|
||||||
return fuelConsumption;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Перезаписаний метод toString для представлення об'єкту автомобіля у вигляді рядка.
|
|
||||||
*
|
|
||||||
* @return рядок, що містить всі властивості абстрактного автомобіля
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return String.format("%-10s | %-7s | %-6s | %-6d | %-5d | %-5s | ",
|
|
||||||
make, model, year, price, speed, fuelConsumption);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Клас SortByFuelConsuming реалізує інтерфейс Comparator і використовується для порівняння автомобілів
|
|
||||||
* за споживанням палива.
|
|
||||||
*/
|
|
||||||
class SortByFuelConsuming implements Comparator<Car> {
|
|
||||||
/**
|
|
||||||
* Метод compare порівнює два об'єкти Car за споживанням палива.
|
|
||||||
* Він порівнює значення споживання палива для обох автомобілів.
|
|
||||||
*
|
|
||||||
* @param a перший автомобіль
|
|
||||||
* @param b другий автомобіль
|
|
||||||
* @return -1, 0 або 1, якщо перше значення менше, рівне або більше другого відповідно
|
|
||||||
*/
|
|
||||||
public int compare(Car a, Car b) {
|
|
||||||
return Double.compare(a.getFuelConsumption(), b.getFuelConsumption());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Щоб реалізувати ієрархію я рішив використати абстрактний клас машини, який має всі базові якості машини
|
|
||||||
// його нащадки мають додаткове поле, крім того різних типів
|
|
||||||
// Клас SortByFuelConsuming є інтерфейсом Comparator і використовується для порівняння автомобілів
|
|
||||||
// за споживанням палива.
|
|
||||||
// повертає значення за яким потім буде сортуватися масив машин
|
|
||||||
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
package Lab6;
|
|
||||||
|
|
||||||
public class Coupe extends Car {
|
|
||||||
private final String bodyType;
|
|
||||||
// Клас купе має додатковий тип який визначає тип кузова, або можна написати чи машина без криші чи з кришою
|
|
||||||
public Coupe(String make, String model, int year, int price, int speed, double fuelConsumption, String bodyType) {
|
|
||||||
super(make, model, year, price, speed, fuelConsumption);
|
|
||||||
this.bodyType = bodyType;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getBodyType() {
|
|
||||||
return bodyType;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
|
|
||||||
return super.toString()+ String.format("Type: %-10s |" , bodyType); // викликаємо супер-метод, додаємо тип кузова
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
package Lab6;
|
|
||||||
|
|
||||||
public class Hatchback extends Car {
|
|
||||||
private int numberOfDoors;
|
|
||||||
// Клас Hatchback має додаткову властивість - кількість дверей
|
|
||||||
public Hatchback(String make, String model, int year, int price, int speed, double fuelConsumption, int numberOfDoors) {
|
|
||||||
super(make, model, year, price, speed, fuelConsumption);
|
|
||||||
this.numberOfDoors = numberOfDoors;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getNumberOfDoors() {
|
|
||||||
return numberOfDoors;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setNumberOfDoors(int numberOfDoors) {
|
|
||||||
this.numberOfDoors = numberOfDoors;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return super.toString() + String.format("Doors: %-10d |" , numberOfDoors); // додаємо до супер-методу нову властивість
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
package Lab6;
|
|
||||||
|
|
||||||
public class Sedan extends Car {
|
|
||||||
private int seatingCapacity;
|
|
||||||
// У об'єктів класу седан особливим є кільість пасажирських місць
|
|
||||||
public Sedan(String make, String model, int year,int price, int speed, double fuelConsumption, int seatingCapacity) {
|
|
||||||
super(make, model, year, price, speed, fuelConsumption);
|
|
||||||
this.seatingCapacity = seatingCapacity;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getSeatingCapacity() {
|
|
||||||
return seatingCapacity;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setSeatingCapacity(int seatingCapacity) {
|
|
||||||
this.seatingCapacity = seatingCapacity;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return super.toString() + String.format("Seats: %-10d |" , seatingCapacity); // додаємо до супер-методу додаткову властивість
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,182 +0,0 @@
|
|||||||
package Lab6;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Scanner;
|
|
||||||
|
|
||||||
public class TaxiPark {
|
|
||||||
|
|
||||||
private static List<Car> cars;
|
|
||||||
|
|
||||||
public TaxiPark() {
|
|
||||||
cars = new ArrayList<>();
|
|
||||||
} // Створюємо у таксопарка масив машин
|
|
||||||
|
|
||||||
public void addAutomobile(Car car) {cars.add(car);} // Метод для додавання машини у таксопарк
|
|
||||||
|
|
||||||
// Метод для додавання машини у таксопарк, але користувачем
|
|
||||||
public void addAutomobileConsole(String carType, String maker, String model, int year, int price, int speed, double fuelConsumption, Object additionalProperty){
|
|
||||||
Car car;
|
|
||||||
switch (carType) { // Удосконалений switch для створення конкретного типу машини
|
|
||||||
case "Coupe" ->
|
|
||||||
car = new Coupe(maker, model, year, price, speed, fuelConsumption, (String) additionalProperty); //
|
|
||||||
// Я придумав, що у купе поліморфізм виражається у тому, що вона може бути купе, без криші, туфелькою
|
|
||||||
// я дуже погано в машинах розбираюсь, тому надіюсь ви мене зрозуміли
|
|
||||||
case "Hatchback", "Sedan" ->
|
|
||||||
car = new Hatchback(maker, model, year, price, speed, fuelConsumption, (int) additionalProperty);
|
|
||||||
default -> {
|
|
||||||
System.out.println("Invalid car type");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
addAutomobile(car); // Виклик метода для додаваня машини у таксопарк, можна було без нього,
|
|
||||||
// одною строкою, але так мені це показалось логічним
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public double calculateFleetCost() { // Метод для обрахунку ціни усіх машин
|
|
||||||
double totalCost = 0.0;
|
|
||||||
for (Car car : cars) {
|
|
||||||
totalCost += car.getPrice(); // Перебираємо усі машини, викликаємо у них метод getPrice()
|
|
||||||
}
|
|
||||||
return totalCost; // Повертаємо результат
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<Car> findCarsBySpeedRange(int minSpeed, int maxSpeed) { // Метод для знаходження машин у діапазоні
|
|
||||||
List<Car> carsInSpeedRange = new ArrayList<>();
|
|
||||||
for (Car car : cars) {
|
|
||||||
if (car.getSpeed() >= minSpeed && car.getSpeed() <= maxSpeed) {
|
|
||||||
carsInSpeedRange.add(car); // Перебираємо машини, які задовольняються умові діапазону
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return carsInSpeedRange;
|
|
||||||
}
|
|
||||||
public void boardCars(List<Car> cars){ // Метод для будування таблиці, приймає масив машин, і створює красиву табличку
|
|
||||||
System.out.println("----------------------------------------------------------------------------");
|
|
||||||
System.out.printf("%-10s | %-7s | %-6s | %-6s | %-5s | %-5s | %-10s | %n",
|
|
||||||
"Maker", "Model", "Year", "Price", "Speed", "Fuel", "Special");
|
|
||||||
System.out.println("----------------------------------------------------------------------------");
|
|
||||||
for (Car car : cars) {
|
|
||||||
System.out.println(car.toString());
|
|
||||||
}
|
|
||||||
System.out.println("----------------------------------------------------------------------------");
|
|
||||||
}
|
|
||||||
|
|
||||||
public void sortByFuelConsumption() { // Метод у таксопарка, який викликає клас для сортування
|
|
||||||
|
|
||||||
cars.sort(new SortByFuelConsuming());
|
|
||||||
boardCars(TaxiPark.cars); // будуємо відсортовану табличку
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void main(String[] args) {
|
|
||||||
int C13 = 2401 % 13;
|
|
||||||
System.out.println("C13 - " + C13 + ", отже треба створити таксопар та ієрархію автомобілів.");
|
|
||||||
System.out.println("--------------------------------------------------------------\n");
|
|
||||||
|
|
||||||
TaxiPark taxiPark = new TaxiPark();
|
|
||||||
|
|
||||||
// Додати автомобілі до таксопарку
|
|
||||||
taxiPark.addAutomobile(new Sedan("Toyota", "Camry", 2020, 3500, 220, 7.5, 5));
|
|
||||||
taxiPark.addAutomobile(new Coupe("BMW", "M4", 2021, 3000, 150, 9.2, "Coupe"));
|
|
||||||
taxiPark.addAutomobile(new Hatchback("Volkswagen", "Golf", 2019, 6000, 200, 6.8, 6));
|
|
||||||
|
|
||||||
Scanner scanner = new Scanner(System.in); // Під'єднуємо сканер
|
|
||||||
boolean quit = false;
|
|
||||||
while (!quit) { // Нескінченний цикл поки користувач не введе 'q'
|
|
||||||
|
|
||||||
System.out.print("""
|
|
||||||
Enter:
|
|
||||||
'cost' - show total fleet
|
|
||||||
'sort' - show cars sorted by fuel consumption
|
|
||||||
'board' - show cars
|
|
||||||
'add' - buy car on your TaxiPark
|
|
||||||
'find' - find cars that in speed diapason
|
|
||||||
or enter 'q' to exit:\s""");
|
|
||||||
String input = scanner.nextLine();
|
|
||||||
// Перевірка чи правильно введено слово
|
|
||||||
if (!input.equals("cost") && !input.equals("sort") && !input.equals("board") && !input.equals("add") && !input.equals("q") && !input.equals("find")) {
|
|
||||||
System.out.println("Invalid field to sort by! Please enter 'cost', 'sort', 'board', 'add', 'find'.");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// Перевірка виходу з програми
|
|
||||||
if (input.equals("q")) {
|
|
||||||
quit = true;
|
|
||||||
System.out.println("Closing program...");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (input.equals("cost")){
|
|
||||||
// Порахувати вартість автопарку
|
|
||||||
double fleetCost = taxiPark.calculateFleetCost(); // Викликаємо метод, який вже описав
|
|
||||||
System.out.println("Total fleet cost: $" + fleetCost);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (input.equals("sort")){
|
|
||||||
// Відсортувати автомобілі за витратами палива
|
|
||||||
taxiPark.sortByFuelConsumption();
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (input.equals("board")){
|
|
||||||
taxiPark.boardCars(TaxiPark.cars); // Виведення таблички
|
|
||||||
continue;
|
|
||||||
|
|
||||||
}
|
|
||||||
if (input.equals("find")){
|
|
||||||
int minSpeed, maxSpeed;
|
|
||||||
System.out.println("Enter min speed: "); // Користувач вводе межі діапазона
|
|
||||||
minSpeed = scanner.nextInt();
|
|
||||||
System.out.println("Enter max speed:");
|
|
||||||
maxSpeed = scanner.nextInt();
|
|
||||||
scanner.nextLine(); // Тут залишався \n тому ми його з'їли
|
|
||||||
List<Car> carsInSpeedRange = taxiPark.findCarsBySpeedRange(minSpeed, maxSpeed); // Масив машин діапазону
|
|
||||||
System.out.println("Cars within the speed range of " + minSpeed + " km/h to " + maxSpeed + " km/h:");
|
|
||||||
taxiPark.boardCars(carsInSpeedRange); // Створенний масив передаємо методу для будування таблички
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
if (input.equals("add")){
|
|
||||||
// Користувач вводе багато значень, перевірки не добавив, тому акуратно)
|
|
||||||
System.out.println("Choose type of car: 'Sedan', 'Coupe', 'Hatchback'");
|
|
||||||
String carType = scanner.nextLine();
|
|
||||||
System.out.println("Enter Maker: ");
|
|
||||||
String maker = scanner.nextLine();
|
|
||||||
System.out.println("Enter Model: ");
|
|
||||||
String model = scanner.nextLine();
|
|
||||||
System.out.println("Enter year: ");
|
|
||||||
int year = scanner.nextInt();
|
|
||||||
System.out.println("Enter price (int)");
|
|
||||||
int price = scanner.nextInt();
|
|
||||||
System.out.println("Enter speed (int)");
|
|
||||||
int speed = scanner.nextInt();
|
|
||||||
System.out.println("Enter fuel consumption");
|
|
||||||
double fuelConsumption = scanner.nextDouble();
|
|
||||||
scanner.nextLine();
|
|
||||||
Object additionalProperty = null; // Абстрактний об'єкт, далі в switch він набуде тип
|
|
||||||
|
|
||||||
switch (carType) {
|
|
||||||
case "Sedan", "Hatchback" -> {
|
|
||||||
System.out.println("Enter special(int):");
|
|
||||||
additionalProperty = scanner.nextInt();
|
|
||||||
}
|
|
||||||
|
|
||||||
case "Coupe" -> {
|
|
||||||
System.out.println("Enter special(any):");
|
|
||||||
additionalProperty = scanner.nextLine();
|
|
||||||
}
|
|
||||||
default -> System.out.println("Invalid car type");
|
|
||||||
}
|
|
||||||
// Передаємо всі введені значення методу для купівлі машини у таксопарк
|
|
||||||
taxiPark.addAutomobileConsole(carType, maker, model, year, price, speed, fuelConsumption, additionalProperty);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
15
src/Main.java
Normal file
15
src/Main.java
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
public class Main {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
System.out.println(args[2]);
|
||||||
|
System.out.println("Hello world!");
|
||||||
|
// System.out.println(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void myFunction() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int myFunction2() {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
30
src/_12_Закревський_Данило_Сергійович/lab1/FirstLab.java
Normal file
30
src/_12_Закревський_Данило_Сергійович/lab1/FirstLab.java
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
public class FirstLab {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Scanner scn = new Scanner(System.in);
|
||||||
|
final int C = 0;
|
||||||
|
double S = 0.0;
|
||||||
|
System.out.print("Enter a: ");
|
||||||
|
int a = scn.nextInt();
|
||||||
|
System.out.print("Enter b: ");
|
||||||
|
int b = scn.nextInt();
|
||||||
|
System.out.print("Enter n: ");
|
||||||
|
int n = scn.nextInt();
|
||||||
|
System.out.print("Enter m: ");
|
||||||
|
int m = scn.nextInt();
|
||||||
|
if ((a <= 0 & n >= 0) | (b <= 0 & m >= 0)){
|
||||||
|
System.out.println("Division by 0!");
|
||||||
|
} else {
|
||||||
|
for (char i = (char) a; i <= n; i++) {
|
||||||
|
for(char j = (char) b; j <= m; j++) {
|
||||||
|
S += (double) (i % j) / (i + C);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
System.out.printf("Result - %.3f", S);
|
||||||
|
}
|
||||||
|
|
||||||
|
scn.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
63
src/_12_Закревський_Данило_Сергійович/lab2/SecondLab.java
Normal file
63
src/_12_Закревський_Данило_Сергійович/lab2/SecondLab.java
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
import java.util.Scanner;
|
||||||
|
import java.util.Random;
|
||||||
|
|
||||||
|
public class SecondLab {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Scanner scn = new Scanner(System.in);
|
||||||
|
Random rnd = new Random();
|
||||||
|
System.out.print("Enter number of rows in matrix A: ");
|
||||||
|
int mA = scn.nextInt();
|
||||||
|
System.out.print("Enter the number of columns in matrix A: ");
|
||||||
|
int nA = scn.nextInt();
|
||||||
|
System.out.print("Enter number of rows in matrix B: ");
|
||||||
|
int mB = scn.nextInt();
|
||||||
|
System.out.print("Enter the number of columns in matrix B: ");
|
||||||
|
int nB = scn.nextInt();
|
||||||
|
long largest, sum = 0L;
|
||||||
|
if(mA != mB || nA != nB) {
|
||||||
|
System.out.println("Unable to add matrices!");
|
||||||
|
} else {
|
||||||
|
long[][] matrixA = new long[mA][nA];
|
||||||
|
long[][] matrixB = new long[mB][nB];
|
||||||
|
long[][] matrixC = new long[mA][nA];
|
||||||
|
|
||||||
|
System.out.println("Matrix A: ");
|
||||||
|
for(int i = 0; i < mA; i++) {
|
||||||
|
for(int j = 0; j < nA; j++) {
|
||||||
|
matrixA[i][j] = rnd.nextLong(10, 50) + 10;
|
||||||
|
System.out.printf("|%d", matrixA[i][j]);
|
||||||
|
}
|
||||||
|
System.out.println("|");
|
||||||
|
}
|
||||||
|
System.out.println("Matrix B: ");
|
||||||
|
for(int i = 0; i < nA; i++) {
|
||||||
|
for(int j = 0; j < nB; j++) {
|
||||||
|
matrixB[i][j] = rnd.nextLong(10, 50) + 10;
|
||||||
|
System.out.printf("|%d", matrixB[i][j]);
|
||||||
|
}
|
||||||
|
System.out.println("|");
|
||||||
|
}
|
||||||
|
System.out.println("Matrix C: ");
|
||||||
|
for(int i = 0; i < mA; i++) {
|
||||||
|
for(int j = 0; j < nA; j++) {
|
||||||
|
matrixC[i][j] = matrixA[i][j] + matrixB[i][j];
|
||||||
|
System.out.printf("|%d", matrixC[i][j]);
|
||||||
|
}
|
||||||
|
System.out.println("|");
|
||||||
|
}
|
||||||
|
for(long[] row: matrixC) {
|
||||||
|
largest = row[0];
|
||||||
|
for(long elem : row) {
|
||||||
|
if(elem > largest) {
|
||||||
|
largest = elem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sum += largest;
|
||||||
|
}
|
||||||
|
System.out.printf("Sum = %d", sum);
|
||||||
|
}
|
||||||
|
scn.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
33
src/_12_Закревський_Данило_Сергійович/lab3/ThirdLab.java
Normal file
33
src/_12_Закревський_Данило_Сергійович/lab3/ThirdLab.java
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
public class ThirdLab {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Scanner scn = new Scanner(System.in);
|
||||||
|
System.out.print("Enter a string: ");
|
||||||
|
String text = scn.nextLine();
|
||||||
|
StringBuilder textBuilder = new StringBuilder(text);
|
||||||
|
System.out.print("Enter a string to replace the words: ");
|
||||||
|
String replace = scn.nextLine();
|
||||||
|
System.out.print("Enter the length of the words to replace: ");
|
||||||
|
int length = scn.nextInt();
|
||||||
|
String[] words = textBuilder.toString().split("\\s+");
|
||||||
|
textBuilder.setLength(0);
|
||||||
|
for(String word : words) {
|
||||||
|
if(word.charAt(word.length()-1) == '.' && word.length() - 1 == length) {
|
||||||
|
textBuilder.append(replace + ". ");
|
||||||
|
} else if (word.charAt(word.length() - 1) == '!' && word.length() - 1 == length) {
|
||||||
|
textBuilder.append(replace + "! ");
|
||||||
|
} else if (word.charAt(word.length() - 1) == '?' && word.length() - 1 == length) {
|
||||||
|
textBuilder.append(replace + "? ");
|
||||||
|
} else if (word.length() == length) {
|
||||||
|
textBuilder.append(replace + " ");
|
||||||
|
} else {
|
||||||
|
textBuilder.append(word + " ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.printf("Result: %s", textBuilder);
|
||||||
|
scn.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
59
src/_12_Закревський_Данило_Сергійович/lab4/Airplane.java
Normal file
59
src/_12_Закревський_Данило_Сергійович/lab4/Airplane.java
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
import java.util.Comparator;
|
||||||
|
|
||||||
|
public class Airplane {
|
||||||
|
private String name;
|
||||||
|
private String type;
|
||||||
|
private int weight;
|
||||||
|
private int amountOfEngines;
|
||||||
|
private int year;
|
||||||
|
private String color;
|
||||||
|
private int capacity;
|
||||||
|
private int price;
|
||||||
|
|
||||||
|
|
||||||
|
public Airplane(String name, String type, int weight, int amountOfEngines, int year, String color, int capacity, int price) {
|
||||||
|
this.name = name;
|
||||||
|
this.type = type;
|
||||||
|
this.weight = weight;
|
||||||
|
this.amountOfEngines = amountOfEngines;
|
||||||
|
this.year = year;
|
||||||
|
this.color = color;
|
||||||
|
this.capacity = capacity;
|
||||||
|
this.price = price;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getPrice() {
|
||||||
|
return price;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getYear() {
|
||||||
|
return year;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "Plane : " +
|
||||||
|
"name = " + name +
|
||||||
|
", type = " + type +
|
||||||
|
", weight = " + weight + " tons" +
|
||||||
|
", amount of engines = " + amountOfEngines +
|
||||||
|
", year = " + year +
|
||||||
|
", color = " + color +
|
||||||
|
", capacity = " + capacity +
|
||||||
|
", price = " + price + " millions dollars.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class SortByPrice implements Comparator<Airplane> {
|
||||||
|
|
||||||
|
public int compare(Airplane a, Airplane b) {
|
||||||
|
return a.getPrice() - b.getPrice();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class SortByYear implements Comparator<Airplane> {
|
||||||
|
|
||||||
|
public int compare(Airplane a, Airplane b) {
|
||||||
|
return a.getYear() - b.getYear();
|
||||||
|
}
|
||||||
|
}
|
||||||
32
src/_12_Закревський_Данило_Сергійович/lab4/FourthLab.java
Normal file
32
src/_12_Закревський_Данило_Сергійович/lab4/FourthLab.java
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
public class FourthLab {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
final Airplane plane1 = new Airplane("Boeing 747", "passenger", 180, 4, 1970, "Lightblue", 467, 70);
|
||||||
|
final Airplane plane2 = new Airplane("Airbus A380", "passenger", 575, 4, 2003, "Orange", 850, 389);
|
||||||
|
final Airplane plane3 = new Airplane("General Dynamics F-16", "military", 9, 1, 1974, "Grey", 1, 45);
|
||||||
|
final Airplane plane4 = new Airplane("Boeing C-17 Globemaster III", "cargo", 130, 4, 1995, "Grey", 102, 340);
|
||||||
|
final Airplane plane5 = new Airplane("An-225 Mriya", "cargo", 285, 6, 1990, "White", 20, 500);
|
||||||
|
Airplane[] planes = {plane1, plane2, plane3, plane4, plane5};
|
||||||
|
|
||||||
|
System.out.println("List of planes: ");
|
||||||
|
for(Airplane plane : planes) {
|
||||||
|
System.out.println(plane);
|
||||||
|
}
|
||||||
|
System.out.println();
|
||||||
|
|
||||||
|
Arrays.sort(planes, new SortByPrice());
|
||||||
|
System.out.println("Sorted by price: ");
|
||||||
|
for(Airplane plane : planes) {
|
||||||
|
System.out.println(plane);
|
||||||
|
}
|
||||||
|
System.out.println();
|
||||||
|
|
||||||
|
Arrays.sort(planes, new SortByYear().reversed());
|
||||||
|
System.out.println("Sorted by year: ");
|
||||||
|
for(Airplane plane : planes) {
|
||||||
|
System.out.println(plane);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
139
src/_12_Закревський_Данило_Сергійович/lab5/FifthLab.java
Normal file
139
src/_12_Закревський_Данило_Сергійович/lab5/FifthLab.java
Normal file
@@ -0,0 +1,139 @@
|
|||||||
|
import java.util.Scanner;
|
||||||
|
|
||||||
|
public class FifthLab {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Scanner scn = new Scanner(System.in);
|
||||||
|
System.out.println("Enter a string: ");
|
||||||
|
String text = scn.nextLine();
|
||||||
|
StringBuilder textBuilder = new StringBuilder(text);
|
||||||
|
StringBuilder result = new StringBuilder();
|
||||||
|
|
||||||
|
System.out.print("Enter a string to replace the words: ");
|
||||||
|
String replace = scn.nextLine();
|
||||||
|
System.out.print("Enter the length of the words to replace: ");
|
||||||
|
int length = scn.nextInt();
|
||||||
|
|
||||||
|
System.out.println("\nText before changes: ");
|
||||||
|
System.out.println(textBuilder);
|
||||||
|
|
||||||
|
|
||||||
|
String[] mySentence = textBuilder.toString().split("(?<=[!.?])\\s?");
|
||||||
|
for(String s: mySentence) {
|
||||||
|
StringBuilder sb = new StringBuilder(s);
|
||||||
|
Sentence sentence = new Sentence(sb, length, replace);
|
||||||
|
result.append(sentence.wordsSplit());
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println("\nText after changes: ");
|
||||||
|
System.out.println(result);
|
||||||
|
scn.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Sentence {
|
||||||
|
|
||||||
|
private final StringBuilder sentence;
|
||||||
|
private final int length;
|
||||||
|
private final String replace;
|
||||||
|
|
||||||
|
public Sentence(StringBuilder sentence, int length, String replace) {
|
||||||
|
this.sentence = sentence;
|
||||||
|
this.length = length;
|
||||||
|
this.replace = replace;
|
||||||
|
}
|
||||||
|
|
||||||
|
public StringBuilder wordsSplit() {
|
||||||
|
StringBuilder ReturnSentence = new StringBuilder();
|
||||||
|
String text = sentence.toString();
|
||||||
|
String[] words = text.split(" ");
|
||||||
|
for(String s: words) {
|
||||||
|
StringBuilder sb = new StringBuilder(s);
|
||||||
|
Word word = new Word(sb, length, replace);
|
||||||
|
ReturnSentence.append(word.lettersSplit()).append(" ");
|
||||||
|
}
|
||||||
|
|
||||||
|
return ReturnSentence;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Word {
|
||||||
|
|
||||||
|
private final StringBuilder word;
|
||||||
|
private final int length;
|
||||||
|
private final String replace;
|
||||||
|
|
||||||
|
public Word(StringBuilder word, int length, String replace) {
|
||||||
|
this.word = word;
|
||||||
|
this.length = length;
|
||||||
|
this.replace = replace;
|
||||||
|
}
|
||||||
|
|
||||||
|
public StringBuilder lettersSplit() {
|
||||||
|
StringBuilder ReturnWord = new StringBuilder();
|
||||||
|
String wordstr = word.toString();
|
||||||
|
int len = wordstr.length();
|
||||||
|
String[] letters = wordstr.split("");
|
||||||
|
String[] ReplaceLetters = replace.split("");
|
||||||
|
char last = wordstr.charAt(word.length() - 1);
|
||||||
|
if(last == '!' || last == '?' || last == '.') {
|
||||||
|
if(wordstr.charAt(word.length() - 2) == '.') {
|
||||||
|
len = wordstr.length() - 3;
|
||||||
|
} else {
|
||||||
|
len = wordstr.length() - 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(len == length) {
|
||||||
|
for(String chr: ReplaceLetters) {
|
||||||
|
StringBuilder ltr = new StringBuilder(chr);
|
||||||
|
Letter letter = new Letter(ltr);
|
||||||
|
ReturnWord.append(letter.getLetter());
|
||||||
|
}
|
||||||
|
if(wordstr.length() - len == 1) {
|
||||||
|
ReturnWord.append(wordstr.charAt(wordstr.length() - 1));
|
||||||
|
} else if(wordstr.length() - len == 3) {
|
||||||
|
ReturnWord.append("...");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for(String chr: letters) {
|
||||||
|
StringBuilder ltr = new StringBuilder(chr);
|
||||||
|
if(chr.equals("!") || chr.equals("?") || chr.equals(".") || chr.equals(",") || chr.equals(":") || chr.equals(";")) {
|
||||||
|
Punctuation punctuation = new Punctuation(ltr);
|
||||||
|
ReturnWord.append(punctuation.getPunctuation());
|
||||||
|
} else {
|
||||||
|
Letter letter = new Letter(ltr);
|
||||||
|
ReturnWord.append(letter.getLetter());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ReturnWord;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Letter {
|
||||||
|
|
||||||
|
private final StringBuilder letter;
|
||||||
|
|
||||||
|
public Letter(StringBuilder letter) {
|
||||||
|
this.letter = letter;
|
||||||
|
}
|
||||||
|
|
||||||
|
public StringBuilder getLetter() {
|
||||||
|
return letter;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class Punctuation {
|
||||||
|
|
||||||
|
private final StringBuilder punctuation;
|
||||||
|
|
||||||
|
public Punctuation(StringBuilder punctuation) {
|
||||||
|
this.punctuation = punctuation;
|
||||||
|
}
|
||||||
|
|
||||||
|
public StringBuilder getPunctuation() {
|
||||||
|
return punctuation;
|
||||||
|
}
|
||||||
|
}
|
||||||
138
src/_12_Закревський_Данило_Сергійович/lab6/SixthLab.java
Normal file
138
src/_12_Закревський_Данило_Сергійович/lab6/SixthLab.java
Normal file
@@ -0,0 +1,138 @@
|
|||||||
|
import java.util.Scanner;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Comparator;
|
||||||
|
|
||||||
|
public class SixthLab {
|
||||||
|
|
||||||
|
public static int sumOfPassangers(Train[] trains) {
|
||||||
|
int sum = 0;
|
||||||
|
for (Train train: trains) {
|
||||||
|
sum += train.getCapacity();
|
||||||
|
}
|
||||||
|
return sum;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static float sumOfLuggage(Train[] trains) {
|
||||||
|
float sum = 0.0f;
|
||||||
|
for (Train train: trains) {
|
||||||
|
sum += train.getLuggage();
|
||||||
|
}
|
||||||
|
return sum;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Scanner scn = new Scanner(System.in);
|
||||||
|
Intercity intercity = new Intercity(2, "intercity", 57, 2.0f);
|
||||||
|
SV sv = new SV(3, "sv", 20, 1.3f);
|
||||||
|
Compartment compartment = new Compartment(2, "compartment", 40, 2.5f);
|
||||||
|
Plackart plackart = new Plackart(1, "plackart", 52, 1.8f);
|
||||||
|
Train[] trainCars = {intercity, sv, compartment, plackart};
|
||||||
|
|
||||||
|
System.out.println("List of train cars: ");
|
||||||
|
for (Train car: trainCars) {
|
||||||
|
System.out.println(car);
|
||||||
|
}
|
||||||
|
|
||||||
|
Arrays.sort(trainCars, new sortByComfort());
|
||||||
|
System.out.println("\nSorted list by comfort level: ");
|
||||||
|
for (Train car: trainCars) {
|
||||||
|
System.out.println(car);
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.printf("\n\nThe total number of passengers on the train - %d.\n", sumOfPassangers(trainCars));
|
||||||
|
System.out.printf("The total amount of train baggage - %.1f tons.", sumOfLuggage(trainCars));
|
||||||
|
|
||||||
|
System.out.println("\n\nFinding the train car by number of passengers");
|
||||||
|
System.out.print("Enter the lower number: ");
|
||||||
|
int lower = scn.nextInt();
|
||||||
|
System.out.print("Enter the extreme number: ");
|
||||||
|
int extreme = scn.nextInt();
|
||||||
|
boolean flag = false;
|
||||||
|
for (Train car: trainCars) {
|
||||||
|
int amount = car.getCapacity();
|
||||||
|
if(amount >= lower && amount <= extreme) {
|
||||||
|
System.out.println(car);
|
||||||
|
flag = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!flag) {
|
||||||
|
System.out.println("There is no such train car");
|
||||||
|
}
|
||||||
|
scn.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Train {
|
||||||
|
private int comfortLevel;
|
||||||
|
private String type;
|
||||||
|
private int capacity;
|
||||||
|
private float luggage;
|
||||||
|
|
||||||
|
public Train(int comfortLevel, String type, int capacity, float luggage) {
|
||||||
|
this.comfortLevel = comfortLevel;
|
||||||
|
this.type = type;
|
||||||
|
this.capacity = capacity;
|
||||||
|
this.luggage = luggage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getComfortLevel() {
|
||||||
|
return comfortLevel;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getType() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getCapacity() {
|
||||||
|
return capacity;
|
||||||
|
}
|
||||||
|
|
||||||
|
public float getLuggage() {
|
||||||
|
return luggage;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "Train : " +
|
||||||
|
" Type: " + type +
|
||||||
|
". Comfort level: " + comfortLevel +
|
||||||
|
". Capacity: " + capacity +
|
||||||
|
". Luggage: " + luggage + " tons.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class Intercity extends Train {
|
||||||
|
|
||||||
|
public Intercity(int comfortLevel, String type, int capacity, float luggage) {
|
||||||
|
super(comfortLevel, type, capacity, luggage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class SV extends Train {
|
||||||
|
|
||||||
|
public SV(int comfortLevel, String type, int capacity, float luggage) {
|
||||||
|
super(comfortLevel, type, capacity, luggage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Compartment extends Train {
|
||||||
|
|
||||||
|
public Compartment(int comfortLevel, String type, int capacity, float luggage) {
|
||||||
|
super(comfortLevel, type, capacity, luggage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Plackart extends Train {
|
||||||
|
|
||||||
|
public Plackart(int comfortLevel, String type, int capacity, float luggage) {
|
||||||
|
super(comfortLevel, type, capacity, luggage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class sortByComfort implements Comparator<Train> {
|
||||||
|
|
||||||
|
public int compare(Train a, Train b){
|
||||||
|
return a.getComfortLevel() - b.getComfortLevel();
|
||||||
|
}
|
||||||
|
}
|
||||||
20
src/encapsulationInheritancePolymorphism/Encapsulation.java
Normal file
20
src/encapsulationInheritancePolymorphism/Encapsulation.java
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package encapsulationInheritancePolymorphism;
|
||||||
|
|
||||||
|
public class Encapsulation {
|
||||||
|
/*private*/ int field;
|
||||||
|
private int field2;
|
||||||
|
// int a = 1;
|
||||||
|
|
||||||
|
public void myMethodForTheField () {
|
||||||
|
System.out.println(field);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void myMethodForTheField2 () {
|
||||||
|
System.out.println(field);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void myMethodForTheFieldAndTheField2 () {
|
||||||
|
System.out.println(field);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +1,10 @@
|
|||||||
|
package encapsulationInheritancePolymorphism;
|
||||||
|
|
||||||
|
public class EncapsulationInheritancePolymorphism {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
int a = 1;
|
||||||
|
// var b = 2;
|
||||||
|
// System.out.println(b);
|
||||||
|
}
|
||||||
|
}
|
||||||
14
src/encapsulationInheritancePolymorphism/Main.java
Normal file
14
src/encapsulationInheritancePolymorphism/Main.java
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package encapsulationInheritancePolymorphism;
|
||||||
|
|
||||||
|
public class Main {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Student student = new Student();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//...
|
||||||
|
|
||||||
|
student.setFaculty("FPM", "MO-22");
|
||||||
|
}
|
||||||
|
}
|
||||||
18
src/encapsulationInheritancePolymorphism/Student.java
Normal file
18
src/encapsulationInheritancePolymorphism/Student.java
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package encapsulationInheritancePolymorphism;
|
||||||
|
|
||||||
|
public class Student {
|
||||||
|
private String name;
|
||||||
|
private String surname;
|
||||||
|
private String group;
|
||||||
|
private String faculty;
|
||||||
|
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFaculty(String faculty, String group) {
|
||||||
|
this.faculty = faculty;
|
||||||
|
this.group = group;
|
||||||
|
}
|
||||||
|
}
|
||||||
13
src/test/A.java
Normal file
13
src/test/A.java
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package test;
|
||||||
|
|
||||||
|
public class A {
|
||||||
|
/*private*/ int f/* = 3*/;
|
||||||
|
|
||||||
|
public int getF() {
|
||||||
|
return f;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setF(int f) {
|
||||||
|
this.f = f;
|
||||||
|
}
|
||||||
|
}
|
||||||
15
src/test/Main.java
Normal file
15
src/test/Main.java
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
package test;
|
||||||
|
|
||||||
|
public class Main {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
A a = new A();
|
||||||
|
System.out.println(a.getF());
|
||||||
|
a.setF(1);
|
||||||
|
System.out.println(a.getF());
|
||||||
|
|
||||||
|
System.out.println(a.f);
|
||||||
|
|
||||||
|
int[] array = {1, 2, 1};
|
||||||
|
System.out.println(array.length);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user