Compare commits

..

7 Commits

Author SHA1 Message Date
xivihwa
9eab1efbc2 lab6 2023-05-22 14:10:26 +03:00
xivihwa
a9dac38d8c Merge branch 'ІО-25/01-Антоненко-Віолетта-Станіславівна' of https://github.com/ASDjonok/OOP_IO-2x_2023 into ІО-25/01-Антоненко-Віолетта-Станіславівна 2023-05-22 13:12:34 +03:00
xivihwa
77e8f72f79 lab5 & update lab4 2023-05-22 13:12:07 +03:00
xivihwa
5c1edd02c8 Update README.md 2023-05-21 23:39:58 +03:00
xivihwa
830f117858 Create README.md 2023-05-18 02:43:11 +03:00
xivihwa
dbe4b8119c lab4 2023-05-18 02:37:48 +03:00
xivihwa
7ce8251e6d Update .gitignore 2023-04-07 18:04:32 +03:00
87 changed files with 908 additions and 1059 deletions

4
.gitignore vendored
View File

@@ -1,2 +1,4 @@
# Project exclude paths
/out/
/out/
# Auto detect text files and perform LF normalization
* text=auto

9
.idea/OOP_IO-2x_2023.iml generated Normal file
View File

@@ -0,0 +1,9 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$" />
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

2
.idea/misc.xml generated
View File

@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<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">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

5
.idea/modules.xml generated
View File

@@ -2,7 +2,10 @@
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/OOP_IO-2x_2023.iml" filepath="$PROJECT_DIR$/OOP_IO-2x_2023.iml" />
<module fileurl="file://$PROJECT_DIR$/.idea/OOP_IO-2x_2023.iml" filepath="$PROJECT_DIR$/.idea/OOP_IO-2x_2023.iml" />
<module fileurl="file://$PROJECT_DIR$/lab1/lab1.iml" filepath="$PROJECT_DIR$/lab1/lab1.iml" />
<module fileurl="file://$PROJECT_DIR$/lab2/lab2.iml" filepath="$PROJECT_DIR$/lab2/lab2.iml" />
<module fileurl="file://$PROJECT_DIR$/lab3/lab3.iml" filepath="$PROJECT_DIR$/lab3/lab3.iml" />
</modules>
</component>
</project>

124
.idea/uiDesigner.xml generated
View File

@@ -1,124 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="Palette2">
<group name="Swing">
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
</item>
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
</item>
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
</item>
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.svg" removable="false" auto-create-binding="false" can-attach-label="true">
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
</item>
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
<initial-values>
<property name="text" value="Button" />
</initial-values>
</item>
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
<initial-values>
<property name="text" value="RadioButton" />
</initial-values>
</item>
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
<initial-values>
<property name="text" value="CheckBox" />
</initial-values>
</item>
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
<initial-values>
<property name="text" value="Label" />
</initial-values>
</item>
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
<preferred-size width="150" height="-1" />
</default-constraints>
</item>
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
<preferred-size width="150" height="-1" />
</default-constraints>
</item>
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
<preferred-size width="150" height="-1" />
</default-constraints>
</item>
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
</item>
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
<preferred-size width="150" height="50" />
</default-constraints>
</item>
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
<preferred-size width="200" height="200" />
</default-constraints>
</item>
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
<preferred-size width="200" height="200" />
</default-constraints>
</item>
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.svg" removable="false" auto-create-binding="true" can-attach-label="true">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
</item>
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
</item>
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
</item>
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
</item>
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
<preferred-size width="-1" height="20" />
</default-constraints>
</item>
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
</item>
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
</item>
</group>
</component>
</project>

2
.idea/vcs.xml generated
View File

@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="$PROJECT_DIR$" vcs="Git" />
<mapping directory="" vcs="Git" />
</component>
</project>

2
README.md Normal file
View File

@@ -0,0 +1,2 @@
# Laboratory OOP - IO-2x - 2023
Antonenko Violetta

8
lab1/FunctionCalculator/.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

1
lab1/FunctionCalculator/.idea/.name generated Normal file
View File

@@ -0,0 +1 @@
Main.java

6
lab1/FunctionCalculator/.idea/misc.xml generated Normal file
View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/FunctionCalculator.iml" filepath="$PROJECT_DIR$/FunctionCalculator.iml" />
</modules>
</component>
</project>

View File

@@ -0,0 +1,51 @@
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
//C2 = 2501 % 2 = 1, і операція O1 буде відніманням (-).
//C3 = 2501 % 3 = 2
//C5 = 2501 % 5 = 1, і операція O2 буде діленням (/).
//C7 = 2501 % 7 = 4, тип індексів i та j буде char.
double result = 0; // результат
char i, j;
char operation1 = '-';
double constant = 2.0;
Scanner scanner = new Scanner(System.in);
System.out.print("Введіть значення n: ");
int n = scanner.nextInt();
System.out.print("Введіть значення m: ");
int m = scanner.nextInt();
// Обчислення значення функції S
for (i = 'a'; i <= 'a' + n - 1; i++) {
for (j = 'b'; j <= 'b' + m - 1; j++) {
try {
double value = (double) i / applyOperation(j, operation1, constant);
result += value;
} catch (ArithmeticException e) {
System.out.println("Ділення на нуль: " + e.getMessage());
} catch (Exception e) {
System.out.println("Виникла помилка: " + e.getMessage());
}
}
}
// Виведення результату
System.out.println("Результат: " + result);
}
// Метод, який застосовує операцію О1 до двох чисел
public static double applyOperation(char j, char operation, double constant) throws Exception {
switch (operation) {
case '-':
return (double) j - constant;
case '/':
if (constant == 0.0) {
throw new ArithmeticException("C не може бути рівним нулю");
} else {
return (double) j / constant;
}
default:
throw new Exception("Непідтримувана операція: " + operation);
}
}
}

11
lab1/lab1.iml Normal file
View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/FunctionCalculator/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

BIN
lab1/lab1.pdf Normal file

Binary file not shown.

8
lab2/Matrix/.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

1
lab2/Matrix/.idea/.name generated Normal file
View File

@@ -0,0 +1 @@
Main.java

6
lab2/Matrix/.idea/misc.xml generated Normal file
View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

8
lab2/Matrix/.idea/modules.xml generated Normal file
View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/Matrix.iml" filepath="$PROJECT_DIR$/Matrix.iml" />
</modules>
</component>
</project>

11
lab2/Matrix/Matrix.iml Normal file
View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

Binary file not shown.

58
lab2/Matrix/src/Main.java Normal file
View File

@@ -0,0 +1,58 @@
import java.util.Arrays;
public class Main {
public static void main(String[] args) {
byte[][] matrix = {{4, 7, 3}, {4, 7, 6}, {7, 10, 9}};
//C5 = 2501 mod 5 = 1, тому C = B^T (транспонування матриці)
//C7 = 2501 mod 7 = 1, тому тип елементів матриці має бути byte
//C11 = 2501 mod 11 = 10, тому треба знайти середнє значення елементів матриці
// Виконуємо дію з матрицею: транспонування матриці B
byte[][] transposedMatrix = transposeMatrix(matrix);
System.out.println("Transposed matrix: ");
printMatrix(transposedMatrix);
// Виконуємо дію з матрицею C: знаходимо середнє значення елементів матриці
double average = calculateAverage(transposedMatrix);
System.out.println("Cереднє значення елементів матриці: " + average);
}
// Метод для транспонування матриці
private static byte[][] transposeMatrix(byte[][] matrix) {
int rows = matrix.length;
int columns = matrix[0].length;
byte[][] transposedMatrix = new byte[columns][rows];
for (int i = 0; i < rows; i++) {
for (int j = 0; j < columns; j++) {
transposedMatrix[j][i] = matrix[i][j];
}
}
return transposedMatrix;
}
// Метод для знаходження середнього значення елементів матриці
private static double calculateAverage(byte[][] matrix) {
int rows = matrix.length;
int columns = matrix[0].length;
int sum = 0;
for (int i = 0; i < rows; i++) {
for (int j = 0; j < columns; j++) {
sum += matrix[i][j];
}
}
return (double) sum / (rows * columns);
}
// Метод для виведення матриці на екран
private static void printMatrix(byte[][] matrix) {
for (byte[] row : matrix) {
System.out.println(Arrays.toString(row));
}
}
}

11
lab2/lab2.iml Normal file
View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/Matrix/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

BIN
lab2/lab2.pdf Normal file

Binary file not shown.

8
lab3/OperationsStrings/.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

1
lab3/OperationsStrings/.idea/.name generated Normal file
View File

@@ -0,0 +1 @@
Main.java

6
lab3/OperationsStrings/.idea/misc.xml generated Normal file
View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/OperationsStrings.iml" filepath="$PROJECT_DIR$/OperationsStrings.iml" />
</modules>
</component>
</project>

View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

View File

@@ -0,0 +1,25 @@
import java.util.HashSet;
public class Main {
public static void main(String[] args) {
String inputText = "Who are you? What is your name? Where are you from?";
int targetLength = 3;
try {
HashSet<String> uniqueWords = new HashSet<String>();
String[] sentences = inputText.split("[?]");
for (String sentence : sentences) {
String[] words = sentence.trim().split("\\s+");
for (String word : words) {
if (word.length() == targetLength) {
uniqueWords.add(word.toLowerCase());
}
}
}
System.out.println("Unique words of length " + targetLength + " in the input text are: " + uniqueWords);
} catch (Exception e) {
System.out.println("An error occurred: " + e.getMessage());
}
}
}

11
lab3/lab3.iml Normal file
View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/OperationsStrings/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

BIN
lab3/lab3.pdf Normal file

Binary file not shown.

8
lab4/.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

9
lab4/.idea/lab4.iml generated Normal file
View File

@@ -0,0 +1,9 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$" />
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

8
lab4/.idea/modules.xml generated Normal file
View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/.idea/lab4.iml" filepath="$PROJECT_DIR$/.idea/lab4.iml" />
</modules>
</component>
</project>

6
lab4/.idea/vcs.xml generated Normal file
View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="$PROJECT_DIR$/.." vcs="Git" />
</component>
</project>

8
lab4/EducationalInstitution/.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/EducationalInstitution.iml" filepath="$PROJECT_DIR$/EducationalInstitution.iml" />
</modules>
</component>
</project>

View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

8
lab4/untitled/.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

6
lab4/untitled/.idea/misc.xml generated Normal file
View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

8
lab4/untitled/.idea/modules.xml generated Normal file
View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/untitled.iml" filepath="$PROJECT_DIR$/untitled.iml" />
</modules>
</component>
</project>

Binary file not shown.

Binary file not shown.

View File

@@ -0,0 +1,56 @@
import java.util.*;
public class Main {
public static void main(String[] args) {
List<SeaShip> ships = createList();
printList(ships);
ships = sortList(ships);
System.out.println("==============================");
printList(ships);
}
private static ArrayList<SeaShip> createList() {
ArrayList<SeaShip> ships = new ArrayList<>();
Random random = new Random();
for (int i = 0; i < 10; i++)
ships.add(new SeaShip("name" + (i + 1), "class" + (i + 1), "type" + (i + 1),
random.nextInt(10000) + 1000, random.nextDouble() * 100 + 20,
random.nextInt(10000) + 1000, random.nextDouble() * 100));
// ships.add(new SeaShip("nameA", "classA", "typeA",
// random.nextInt(10000) + 1000, 100d,
// random.nextInt(10000) + 1000, 120d));
// ships.add(new SeaShip("nameA", "classA", "typeA",
// random.nextInt(10000) + 1000, 100d,
// random.nextInt(10000) + 1000, 130d));
// ships.add(new SeaShip("nameA", "classA", "typeA",
// random.nextInt(10000) + 1000, 100d,
// random.nextInt(10000) + 1000, 140d));
// ships.add(new SeaShip("nameA", "classA", "typeA",
// random.nextInt(10000) + 1000, 120d,
// random.nextInt(10000) + 1000, 120d));
// ships.add(new SeaShip("nameA", "classA", "typeA",
// random.nextInt(10000) + 1000, 120d,
// random.nextInt(10000) + 1000, 100d));
return ships;
}
private static List<SeaShip> sortList(List<SeaShip> list) {
Comparator<SeaShip> comparator = Comparator.comparing(SeaShip::getLength).reversed()
.thenComparing(SeaShip::getMaxSpeed);
list.sort(comparator);
return list;
}
private static void printList(List<SeaShip> list) {
list.forEach(System.out::println);
}
}

View File

@@ -0,0 +1,86 @@
public class SeaShip {
private String name;
private String shipClass;
private String type;
private Integer weight;
private Double length;
private Integer power;
private Double maxSpeed;
public SeaShip(String name, String shipClass, String type,
Integer weight, Double length, Integer power, Double maxSpeed) {
this.name = name;
this.shipClass = shipClass;
this.type = type;
this.weight = weight;
this.length = length;
this.power = power;
this.maxSpeed = maxSpeed;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getShipClass() {
return shipClass;
}
public void setShipClass(String shipClass) {
this.shipClass = shipClass;
}
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public Integer getWeight() {
return weight;
}
public void setWeight(Integer weight) {
this.weight = weight;
}
public Double getLength() {
return length;
}
public void setLength(Double length) {
this.length = length;
}
public Integer getPower() {
return power;
}
public void setPower(Integer power) {
this.power = power;
}
public Double getMaxSpeed() {
return maxSpeed;
}
public void setMaxSpeed(Double maxSpeed) {
this.maxSpeed = maxSpeed;
}
@Override
public String toString() {
return "Sea ship '" + name + "', class: " + shipClass + ", type: " + type + ".\n" +
"Weight: " + weight + "\n" +
"Length: " + length + "\n" +
"Engine power: " + power + "\n" +
"Max speed: " + maxSpeed + "\n";
}
}

View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

BIN
lab5/lab5.pdf Normal file

Binary file not shown.

8
lab5/untitled/.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

6
lab5/untitled/.idea/misc.xml generated Normal file
View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

8
lab5/untitled/.idea/modules.xml generated Normal file
View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/untitled.iml" filepath="$PROJECT_DIR$/untitled.iml" />
</modules>
</component>
</project>

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

166
lab5/untitled/src/Main.java Normal file
View File

@@ -0,0 +1,166 @@
import java.util.HashSet;
public class Main {
public static void main(String[] args) {
String inputText = "Раз два три, літо прийди! По ООП сто балів захвати. ім'я запише без апострофу, ех"; //вход даних, текст
int targetLength = 3; //змінна, кількість літер в слові
try {
TextProcessor textProcessor = new TextProcessor();
HashSet<Word> uniqueWords = textProcessor.findUniqueWordsWithLength(inputText, targetLength);
System.out.println("Unique words of length " + targetLength + " in the input text are: " + uniqueWords);// вивод повідомлення, що містить довжину та унікальні слова змінної
} catch (Exception e) {
System.out.println("An error occurred: " + e.getMessage());//вивиод помилки
}
}
}
class Letter {
private char value;
public Letter(char value) {
this.value = value;
}
public char getValue() {
return value;
}
public void setValue(char value) {
this.value = value;
}
}
class Word {
private Letter[] letters;
public Word(Letter[] letters) {
this.letters = letters;
}
public Letter[] getLetters() {
return letters;
}
public void setLetters(Letter[] letters) {
this.letters = letters;
}
public int getLength() {
return letters.length;
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
for (Letter letter : letters) {
sb.append(letter.getValue());
}
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null || getClass() != obj.getClass()) {
return false;
}
Word other = (Word) obj;
return this.toString().equals(other.toString());
}
@Override
public int hashCode() {
return this.toString().hashCode();
}
}
class Sentence {
private Word[] words;
private String punctuation;
public Sentence(Word[] words, String punctuation) {
this.words = words;
this.punctuation = punctuation;
}
public Word[] getWords() {
return words;
}
public void setWords(Word[] words) {
this.words = words;
}
public String getPunctuation() {
return punctuation;
}
public void setPunctuation(String punctuation) {
this.punctuation = punctuation;
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
for (Word word : words) {
sb.append(word.toString()).append(" ");
}
sb.append(punctuation);
return sb.toString();
}
}
class Text {
private Sentence[] sentences;
public Text(Sentence[] sentences) {
this.sentences = sentences;
}
public Sentence[] getSentences() {
return sentences;
}
public void setSentences(Sentence[] sentences) {
this.sentences = sentences;
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
for (Sentence sentence : sentences) {
sb.append(sentence.toString());
}
return sb.toString();
}
}
class TextProcessor {
public HashSet<Word> findUniqueWordsWithLength(String inputText, int targetLength) {
HashSet<Word> uniqueWords = new HashSet<>();
String[] sentenceStrings = inputText.split("[?]");
for (String sentenceString : sentenceStrings) {
String[] wordStrings = sentenceString.trim().split("\\s+");
for (String wordString : wordStrings) {
wordString = wordString.replaceAll("[\\t\\s]+", " "); // Заміна послідовності табуляцій та пробілів одним пробілом
wordString = wordString.replaceAll("[^\\p{L}\\s]", ""); // Вилучення розділових знаків
wordString = wordString.toLowerCase(); // Перетворення на нижній регістр
wordString = wordString.replace("", ""); // Вилучення апострофів
if (wordString.length() == targetLength) {
Letter[] letters = new Letter[wordString.length()];
for (int i = 0; i < wordString.length(); i++) {
letters[i] = new Letter(wordString.charAt(i));
}
Word word = new Word(letters);
uniqueWords.add(word);
}
}
}
return uniqueWords;
}
}

View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

BIN
lab6/lab6.pdf Normal file

Binary file not shown.

8
lab6/untitled/.idea/.gitignore generated vendored Normal file
View File

@@ -0,0 +1,8 @@
# Default ignored files
/shelf/
/workspace.xml
# Editor-based HTTP Client requests
/httpRequests/
# Datasource local storage ignored files
/dataSources/
/dataSources.local.xml

6
lab6/untitled/.idea/misc.xml generated Normal file
View File

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectRootManager" version="2" languageLevel="JDK_19" default="true" project-jdk-name="openjdk-19" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

8
lab6/untitled/.idea/modules.xml generated Normal file
View File

@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/untitled.iml" filepath="$PROJECT_DIR$/untitled.iml" />
</modules>
</component>
</project>

Binary file not shown.

159
lab6/untitled/src/Main.java Normal file
View File

@@ -0,0 +1,159 @@
import java.util.Arrays;
import java.util.Comparator;
/**
* Клас, що описує базовий рухомий склад залізничного транспорту.
*/
class RollingStock {
private int number;
public RollingStock(int number) {
this.number = number;
}
public int getNumber() {
return number;
}
}
/**
* Клас, що описує пасажирський вагон.
*/
class PassengerCarriage extends RollingStock {
private int passengerCount;
private int comfortLevel;
public PassengerCarriage(int number, int passengerCount, int comfortLevel) {
super(number);
this.passengerCount = passengerCount;
this.comfortLevel = comfortLevel;
}
public int getPassengerCount() {
return passengerCount;
}
public int getComfortLevel() {
return comfortLevel;
}
}
/**
* Клас, що описує вагон для багажу.
*/
class BaggageCarriage extends RollingStock {
private int baggageCount;
public BaggageCarriage(int number, int baggageCount) {
super(number);
this.baggageCount = baggageCount;
}
public int getBaggageCount() {
return baggageCount;
}
}
/**
* Клас, що описує пасажирський потяг.
*/
class PassengerTrain {
private RollingStock[] rollingStock;
public PassengerTrain(RollingStock[] rollingStock) {
this.rollingStock = rollingStock;
}
public int getTotalPassengerCount() {
int totalPassengerCount = 0;
for (RollingStock stock : rollingStock) {
if (stock instanceof PassengerCarriage) {
PassengerCarriage carriage = (PassengerCarriage) stock;
totalPassengerCount += carriage.getPassengerCount();
}
}
return totalPassengerCount;
}
public int getTotalBaggageCount() {
int totalBaggageCount = 0;
for (RollingStock stock : rollingStock) {
if (stock instanceof BaggageCarriage) {
BaggageCarriage carriage = (BaggageCarriage) stock;
totalBaggageCount += carriage.getBaggageCount();
}
}
return totalBaggageCount;
}
public void sortByComfortLevel() {
Arrays.sort(rollingStock, new Comparator<RollingStock>() {
@Override
public int compare(RollingStock o1, RollingStock o2) {
if (o1 instanceof PassengerCarriage && o2 instanceof PassengerCarriage) {
PassengerCarriage carriage1 = (PassengerCarriage) o1;
PassengerCarriage carriage2 = (PassengerCarriage) o2;
return carriage1.getComfortLevel() - carriage2.getComfortLevel();
}
return 0;
}
});
}
public RollingStock findCarriageByPassengerCountRange(int minPassengerCount, int maxPassengerCount) {
for (RollingStock stock : rollingStock) {
if (stock instanceof PassengerCarriage) {
PassengerCarriage carriage = (PassengerCarriage) stock;
if (carriage.getPassengerCount() >= minPassengerCount && carriage.getPassengerCount() <= maxPassengerCount) {
return carriage;
}
}
}
return null;
}
}
/**
* Головний клас програми.
*/
public class Main {
public static void main(String[] args) {
// Створення вагонів потягу
RollingStock[] rollingStock = new RollingStock[5];
rollingStock[0] = new PassengerCarriage(1, 40, 3);
rollingStock[1] = new PassengerCarriage(2, 30, 2);
rollingStock[2] = new BaggageCarriage(3, 50);
rollingStock[3] = new PassengerCarriage(4, 20, 1);
rollingStock[4] = new PassengerCarriage(5, 35, 2);
// Створення пасажирського потягу
PassengerTrain train = new PassengerTrain(rollingStock);
// Розрахунок загальної кількості пасажирів та багажу в потязі
int totalPassengerCount = train.getTotalPassengerCount();
int totalBaggageCount = train.getTotalBaggageCount();
System.out.println("Total passenger count: " + totalPassengerCount);
System.out.println("Total baggage count: " + totalBaggageCount);
// Сортування вагонів за рівнем комфортності
train.sortByComfortLevel();
System.out.println("Sorted carriages by comfort level:");
for (RollingStock stock : rollingStock) {
if (stock instanceof PassengerCarriage) {
PassengerCarriage carriage = (PassengerCarriage) stock;
System.out.println("Carriage " + carriage.getNumber() + ", Comfort Level: " + carriage.getComfortLevel());
}
}
// Знаходження вагона з пасажирськими місцями в заданому діапазоні кількості пасажирів
int minPassengerCount = 25;
int maxPassengerCount = 40;
RollingStock foundCarriage = train.findCarriageByPassengerCountRange(minPassengerCount, maxPassengerCount);
if (foundCarriage != null) {
System.out.println("Found carriage with passenger count in range (" + minPassengerCount + "-" + maxPassengerCount + "): " + foundCarriage.getNumber());
} else {
System.out.println("No carriage found with passenger count in range (" + minPassengerCount + "-" + maxPassengerCount + ")");
}
}
}

View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

View File

@@ -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();
}
}

View File

@@ -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);
}
}
}

View File

@@ -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);
}
}

View File

@@ -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
}
}

View File

@@ -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(), який є прикладом поліморфізму
}
}
}

View File

@@ -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 і використовується для порівняння автомобілів
// за споживанням палива.
// повертає значення за яким потім буде сортуватися масив машин

View File

@@ -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); // викликаємо супер-метод, додаємо тип кузова
}
}

View File

@@ -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); // додаємо до супер-методу нову властивість
}
}

View File

@@ -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); // додаємо до супер-методу додаткову властивість
}
}

View File

@@ -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);
}
}
}
}