mirror of
https://github.com/ASDjonok/OOP_IO-2x_2023.git
synced 2026-04-01 21:21:50 +03:00
Compare commits
15 Commits
ІО-23/30-Ш
...
ІО-24/01-Б
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7424afd92e | ||
|
|
6d106ee74f | ||
|
|
3cd448eeda | ||
|
|
81ac59840f | ||
|
|
1e6825d7d4 | ||
|
|
4087daef02 | ||
|
|
31ba116ad8 | ||
|
|
6fc3cc244e | ||
|
|
3bbb7c8e54 | ||
|
|
1af299f8f7 | ||
|
|
4924bbe62f | ||
|
|
29e63163a4 | ||
|
|
399941844f | ||
|
|
f385bff73d | ||
|
|
6d8171ad4c |
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
# Project exclude paths
|
||||
/out/
|
||||
8
.idea/.gitignore
generated
vendored
Normal file
8
.idea/.gitignore
generated
vendored
Normal 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
.idea/misc.xml
generated
Normal file
6
.idea/misc.xml
generated
Normal 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-18" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/out" />
|
||||
</component>
|
||||
</project>
|
||||
8
.idea/modules.xml
generated
Normal file
8
.idea/modules.xml
generated
Normal file
@@ -0,0 +1,8 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<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" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
124
.idea/uiDesigner.xml
generated
Normal file
124
.idea/uiDesigner.xml
generated
Normal file
@@ -0,0 +1,124 @@
|
||||
<?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>
|
||||
6
.idea/vcs.xml
generated
Normal file
6
.idea/vcs.xml
generated
Normal 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>
|
||||
@@ -1,33 +0,0 @@
|
||||
package OOP.Java.lab_1;
|
||||
|
||||
import java.util.Scanner;
|
||||
|
||||
public class lab_1 {
|
||||
|
||||
public static int protectedInput(String variableToRead, Scanner input) {
|
||||
do {
|
||||
try {
|
||||
System.out.printf("Enter %s: ", variableToRead);
|
||||
return input.nextInt();
|
||||
} catch (Exception e) {
|
||||
System.out.printf("%s must be an integer.\n", variableToRead.toUpperCase());
|
||||
input.nextLine();
|
||||
}
|
||||
} while (true);
|
||||
}
|
||||
|
||||
public static void main(String[] args) {
|
||||
Scanner input = new Scanner(System.in);
|
||||
|
||||
final int n = protectedInput("n", input);
|
||||
final int m = protectedInput("m", input);
|
||||
final int a = protectedInput("a", input);
|
||||
final int b = protectedInput("b", input);
|
||||
|
||||
input.close();
|
||||
|
||||
final float s = ((float) (b + m) / 2) * (m - b + 1) * (n - a + 1);
|
||||
|
||||
System.out.println("S = " + s);
|
||||
}
|
||||
}
|
||||
@@ -1,23 +0,0 @@
|
||||
package OOP.Java.lab_1
|
||||
|
||||
fun protectedInput(variableName: String): Int {
|
||||
do {
|
||||
try {
|
||||
print("Enter $variableName: ")
|
||||
return readln().toInt()
|
||||
} catch (e: Exception) {
|
||||
println("${variableName.uppercase()} must be an integer!")
|
||||
}
|
||||
} while (true)
|
||||
}
|
||||
|
||||
fun main() {
|
||||
val n: Int = protectedInput("n")
|
||||
val m: Int = protectedInput("m")
|
||||
val a: Int = protectedInput("a")
|
||||
val b: Int = protectedInput("b")
|
||||
|
||||
val s: Float = (b + m).toFloat() / 2 * (m - b + 1) * (n - a + 1)
|
||||
|
||||
println("S = $s")
|
||||
}
|
||||
@@ -1,109 +0,0 @@
|
||||
package OOP.Java.lab_2;
|
||||
|
||||
import org.jetbrains.annotations.Contract;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
import java.util.Scanner;
|
||||
|
||||
public class lab_2 {
|
||||
|
||||
public static short protectedInput(String inputPrompt, String errorMessage, Scanner input) {
|
||||
short read_variable;
|
||||
|
||||
do {
|
||||
try {
|
||||
System.out.println();
|
||||
System.out.print(inputPrompt);
|
||||
|
||||
read_variable = input.nextShort();
|
||||
break;
|
||||
} catch (Exception e) {
|
||||
System.out.println(errorMessage);
|
||||
input.nextLine();
|
||||
}
|
||||
} while (true);
|
||||
|
||||
return read_variable;
|
||||
}
|
||||
|
||||
@NotNull
|
||||
public static String format(int number) {
|
||||
int width = String.valueOf(number).length() + 1;
|
||||
|
||||
return "|%" + width + "d ";
|
||||
}
|
||||
|
||||
@Contract(pure = true)
|
||||
public static double average(@NotNull short[] row) {
|
||||
short sum = 0;
|
||||
|
||||
for (short element : row) {
|
||||
sum += element;
|
||||
}
|
||||
|
||||
return (double) sum / row.length;
|
||||
}
|
||||
|
||||
public static void main(String[] args) {
|
||||
short rows, columns;
|
||||
|
||||
Scanner input = new Scanner(System.in);
|
||||
|
||||
final short a = protectedInput("Input a constant to multiply a matrix by: ",
|
||||
"A constant must be a short-data type integer, try again.", input);
|
||||
|
||||
System.out.println();
|
||||
System.out.println("Input size of the matrix.");
|
||||
|
||||
do {
|
||||
rows = protectedInput("Rows: ",
|
||||
"A number of rows must be a short-data type integer, try again.", input);
|
||||
} while (rows <= 0);
|
||||
|
||||
do {
|
||||
columns = protectedInput("Columns: ",
|
||||
"A number of columns must be a short-data type integer, try again.", input);
|
||||
} while (columns <= 0);
|
||||
|
||||
input.close();
|
||||
|
||||
short[][] matrix_B = new short[rows][columns];
|
||||
|
||||
System.out.println();
|
||||
System.out.println("Matrix B:");
|
||||
|
||||
String format = format(rows * columns);
|
||||
|
||||
for (short i = 0; i < rows; i++) {
|
||||
for (short j = 0; j < columns; j++) {
|
||||
matrix_B[i][j] = (short) ((i + 1) * (j + 1));
|
||||
|
||||
System.out.printf(format, matrix_B[i][j]);
|
||||
}
|
||||
|
||||
System.out.println("|");
|
||||
}
|
||||
|
||||
System.out.println();
|
||||
System.out.println("Matrix a×B:");
|
||||
|
||||
format = format(rows * columns * a);
|
||||
|
||||
for (short i = 0; i < matrix_B.length; i++) {
|
||||
for (short j = 0; j < matrix_B[i].length; j++) {
|
||||
matrix_B[i][j] *= (a);
|
||||
|
||||
System.out.printf(format, matrix_B[i][j]);
|
||||
}
|
||||
|
||||
System.out.println("|");
|
||||
}
|
||||
|
||||
System.out.println();
|
||||
System.out.println("Averages of each row:");
|
||||
|
||||
for (short[] row : matrix_B) {
|
||||
System.out.println(average(row));
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,57 +0,0 @@
|
||||
package OOP.Java.lab_3;
|
||||
|
||||
public class lab_3 {
|
||||
static int maxStrLength;
|
||||
static String result;
|
||||
|
||||
public static void cSubUtil(StringBuilder stringbuilder, int leftBoundary, int rightBoundary) {
|
||||
String string = stringbuilder.toString().toLowerCase().replaceAll("[^a-z]","");
|
||||
// check if the indices lie in the range of string
|
||||
// and also if it is palindrome
|
||||
while (leftBoundary >= 0 && rightBoundary < string.length() && string.toLowerCase().charAt(leftBoundary) == string.toLowerCase().charAt(rightBoundary)) {
|
||||
// expand the boundary
|
||||
leftBoundary--;
|
||||
rightBoundary++;
|
||||
}
|
||||
// if it's length is greater than maxStrLength update
|
||||
// maxLength and result
|
||||
if (rightBoundary - leftBoundary - 1 >= maxStrLength) {
|
||||
result = string.substring(leftBoundary + 1, rightBoundary);
|
||||
maxStrLength = rightBoundary - leftBoundary - 1;
|
||||
}
|
||||
}
|
||||
|
||||
public static int longestPalSubstr(StringBuilder string)
|
||||
{
|
||||
result = "";
|
||||
maxStrLength = 1;
|
||||
// for every index in the string check palindromes
|
||||
// starting from that index
|
||||
for (int i = 0; i < string.length(); i++) {
|
||||
// check for odd length palindromes
|
||||
cSubUtil(string, i, i);
|
||||
// check for even length palindromes
|
||||
cSubUtil(string, i, i + 1);
|
||||
}
|
||||
System.out.println("Longest palindrome substring is: " + compareStrings(string));
|
||||
return compareStrings(string).length();
|
||||
}
|
||||
|
||||
public static String compareStrings(StringBuilder builder) {
|
||||
for (int leftBoundary = 0; leftBoundary <= builder.length(); leftBoundary++) {
|
||||
for (int rightBoundary = builder.length(); rightBoundary >= leftBoundary; rightBoundary--) {
|
||||
if (result.equals(builder.substring(leftBoundary, rightBoundary).toLowerCase().replaceAll("[^a-z]",""))) {
|
||||
return builder.substring(leftBoundary, rightBoundary);
|
||||
}
|
||||
}
|
||||
}
|
||||
return "";
|
||||
}
|
||||
|
||||
public static void main(String[] args) {
|
||||
StringBuilder stringToDetect = new StringBuilder("Eva, can I see bees in a cave?");
|
||||
|
||||
System.out.println("Initial string: " + stringToDetect);
|
||||
System.out.println("Length is: " + longestPalSubstr(stringToDetect));
|
||||
}
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
package OOP.Java.lab_4
|
||||
|
||||
class Furniture(val name: String, val material: String, val price: Int, val length: Int, val width: Int, val height: Int) {
|
||||
fun print(nameWidth: Int, materialWidth: Int, priceWidth: Int){
|
||||
print("Furniture stats: {")
|
||||
print("Name: ${this.name.padEnd(nameWidth)} ")
|
||||
print("Material: ${this.material.padEnd(materialWidth)} ")
|
||||
print("Price: ${(this.price.toString() + " cu").padEnd(priceWidth + 3)} ")
|
||||
print("Size: ${this.length}×${this.width}×${this.height}};\n")
|
||||
}
|
||||
}
|
||||
@@ -1,26 +0,0 @@
|
||||
package OOP.Java.lab_4
|
||||
|
||||
fun main() {
|
||||
val furnitureArray = arrayOf(
|
||||
Furniture("Chair", "Wood", 10, 5, 5, 10),
|
||||
Furniture("Counter-top", "Marble", 1_000, 10, 5, 1),
|
||||
Furniture("Dinner table", "Glass", 500, 15, 10, 1),
|
||||
Furniture("Office table", "Wood", 200, 10, 7, 1),
|
||||
Furniture("Refrigerator", "Stainless steel", 20_000, 8, 4, 10)
|
||||
)
|
||||
|
||||
val maxNameWidth = furnitureArray.maxWith(Comparator.comparingInt { it.name.length }).name.length
|
||||
val maxMaterialWidth = furnitureArray.maxWith(Comparator.comparingInt { it.material.length }).material.length
|
||||
val maxPriceWidth = furnitureArray.maxWith(Comparator.comparingInt { it.price }).price.toString().length
|
||||
|
||||
println("\nUnsorted array:")
|
||||
for (item in furnitureArray) item.print(maxNameWidth, maxMaterialWidth, maxPriceWidth)
|
||||
|
||||
println("\nSorted alphabetically by name:")
|
||||
furnitureArray.sortBy { it.name }
|
||||
for (item in furnitureArray) item.print(maxNameWidth, maxMaterialWidth, maxPriceWidth)
|
||||
|
||||
println("\nSorted alphabetically by material:")
|
||||
furnitureArray.sortBy { it.material }
|
||||
for (item in furnitureArray) item.print(maxNameWidth, maxMaterialWidth, maxPriceWidth)
|
||||
}
|
||||
@@ -1,23 +0,0 @@
|
||||
package OOP.Java.lab_5
|
||||
|
||||
/**
|
||||
* A class representing a single letter in a word.
|
||||
*
|
||||
* @property character a character value of a Letter.
|
||||
*/
|
||||
class Letter(private val character: Char) {
|
||||
override fun toString(): String {
|
||||
return this.character.toString()
|
||||
}
|
||||
|
||||
/**
|
||||
* Indicates whether the two objects of class Letter are "equal".
|
||||
*
|
||||
* @param letter a letter to compare.
|
||||
* @param ignoreCase if set to "true" will ignore the case of Letters compared.
|
||||
* @return "true" if letters are equal and "false" if they aren't.
|
||||
*/
|
||||
fun letterEquals(letter: Letter, ignoreCase: Boolean): Boolean {
|
||||
return this.character.toString().equals(letter.toString(), ignoreCase)
|
||||
}
|
||||
}
|
||||
@@ -1,19 +0,0 @@
|
||||
package OOP.Java.lab_5
|
||||
|
||||
/**
|
||||
* A class representing a punctuation mark following a word or a sentence.
|
||||
*
|
||||
* @property punctuationMark a [String] value of a punctuation mark.
|
||||
*/
|
||||
class Punctuation(var punctuationMark: String) {
|
||||
|
||||
init {
|
||||
if (!"\\p{Punct}".toRegex().containsMatchIn(punctuationMark)) {
|
||||
this.punctuationMark = ""
|
||||
}
|
||||
}
|
||||
|
||||
override fun toString(): String {
|
||||
return punctuationMark
|
||||
}
|
||||
}
|
||||
@@ -1,35 +0,0 @@
|
||||
package OOP.Java.lab_5
|
||||
|
||||
/**
|
||||
* A class representing a single sentence is a text.
|
||||
*
|
||||
* @property sentenceArray a [Pair] of [Array]s of [Word] and [Punctuation] objects that make up a sentence.
|
||||
*
|
||||
* @constructor a primary constructor accepts a [Pair] of [Array]s of [Word] and [Punctuation] objects, a secondary one accepts a string representing the entire sentence.
|
||||
*/
|
||||
class Sentence(var sentenceArray: Pair<Array<Word>, Array<Punctuation>>) {
|
||||
|
||||
constructor(
|
||||
sentenceString: String
|
||||
) : this(
|
||||
Pair(
|
||||
sentenceString.split("[\\p{Punct}\\s]+".toRegex()).filter { it.isNotEmpty() }.map { word -> Word(word) }.toTypedArray(),
|
||||
sentenceString.split(" ").map { word -> Punctuation(word.last().toString()) }.toTypedArray()
|
||||
)
|
||||
)
|
||||
|
||||
/**
|
||||
* Returns an array of all [Letter] objects in a sentence.
|
||||
*/
|
||||
fun getAllLetters(): Array<Letter> {
|
||||
var allLetters = arrayOf<Letter>()
|
||||
this.sentenceArray.first.forEach { allLetters += it.letters }
|
||||
return allLetters
|
||||
}
|
||||
|
||||
override fun toString(): String {
|
||||
var sentence = arrayOf<String>()
|
||||
this.sentenceArray.first.indices.forEach {sentence += this.sentenceArray.first[it].toString() + this.sentenceArray.second[it].toString() }
|
||||
return sentence.joinToString(" ")
|
||||
}
|
||||
}
|
||||
@@ -1,83 +0,0 @@
|
||||
package OOP.Java.lab_5
|
||||
|
||||
/**
|
||||
* A class representing the entire text.
|
||||
*
|
||||
* @property textArray a [Pair] of [Array]s of [Sentence] and [Punctuation] objects that make up a text.
|
||||
*
|
||||
* @constructor a primary constructor accepts a [Pair] of [Array]s of [Sentence] and [Punctuation] objects, a secondary one accepts a string representing the entire text.
|
||||
*/
|
||||
class Text(var textArray: Pair<Array<Sentence>, Array<Punctuation>>) {
|
||||
|
||||
constructor(
|
||||
textString: String
|
||||
) : this(
|
||||
Pair(
|
||||
textString.split("[.!?] ?".toRegex()).filter { it.isNotEmpty() }.map { sentence -> Sentence(sentence) }.toTypedArray(),
|
||||
textString.split("(?<=[.!?]) ?".toRegex()).filter { it.isNotEmpty() }.map { sentence -> Punctuation(sentence.last().toString()) }.toTypedArray()
|
||||
)
|
||||
)
|
||||
|
||||
/**
|
||||
* Returns an array of all [Letter] objects in a sentence.
|
||||
*/
|
||||
private fun getAllLetters(): Array<Letter> {
|
||||
var allLetters = arrayOf<Letter>()
|
||||
this.textArray.first.forEach { allLetters += it.getAllLetters() }
|
||||
return allLetters
|
||||
}
|
||||
|
||||
/**
|
||||
* Searches for the longest palindromic substring in a given text.
|
||||
*
|
||||
* @return the longest palindromic substring found.
|
||||
*/
|
||||
fun palindromeSearch(): String {
|
||||
var result = " "
|
||||
|
||||
val letters = this.getAllLetters()
|
||||
|
||||
for (leftBoundary in letters.indices) {
|
||||
for (rightBoundary in letters.lastIndex downTo leftBoundary + 1) {
|
||||
val subToC = letters.sliceArray(leftBoundary..rightBoundary)
|
||||
|
||||
if (subToC.first().letterEquals(subToC.last(), true) && this.checkReverse(subToC) && subToC.size > result.length) {
|
||||
result = subToC.joinToString("")
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return result
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if a given substring is a palindrome.
|
||||
*
|
||||
* Is not case-sensitive.
|
||||
*
|
||||
* @param substring an [Array] of [Letter] objects representing a substring.
|
||||
*
|
||||
* @return "true" is a substring given is a palindrome, "false" if it isn't.
|
||||
*/
|
||||
private fun checkReverse(substring: Array<Letter>): Boolean {
|
||||
var leftBoundary = 0
|
||||
var rightBoundary = substring.lastIndex
|
||||
var result = false
|
||||
val correction = substring.size % 2
|
||||
|
||||
while (leftBoundary < substring.size / 2 && rightBoundary >= substring.size / 2 + correction) {
|
||||
leftBoundary++
|
||||
rightBoundary--
|
||||
result = substring[leftBoundary].letterEquals(substring[rightBoundary], true)
|
||||
}
|
||||
|
||||
return result
|
||||
}
|
||||
|
||||
|
||||
override fun toString(): String {
|
||||
var text = arrayOf<String>()
|
||||
this.textArray.first.indices.forEach { text += this.textArray.first[it].toString() + this.textArray.second[it].toString() }
|
||||
return text.joinToString(" ")
|
||||
}
|
||||
}
|
||||
@@ -1,22 +0,0 @@
|
||||
package OOP.Java.lab_5
|
||||
|
||||
/**
|
||||
* A class representing a single word is a sentence.
|
||||
*
|
||||
* @property letters an array of [Letter] objects that make up a word.
|
||||
*
|
||||
* @constructor a primary constructor accepts an array of [Letter] objects, a secondary one accepts a string representing the entire word.
|
||||
*/
|
||||
class Word(var letters: Array<Letter>) {
|
||||
|
||||
override fun toString(): String {
|
||||
val wordString = StringBuilder()
|
||||
this.letters.forEach { wordString.append(it) }
|
||||
|
||||
return wordString.toString()
|
||||
}
|
||||
|
||||
constructor(
|
||||
word: String
|
||||
) : this((word.toCharArray().map { letter -> Letter(letter) }).toTypedArray())
|
||||
}
|
||||
@@ -1,33 +0,0 @@
|
||||
package OOP.Java.lab_6
|
||||
|
||||
import kotlin.time.Duration
|
||||
|
||||
/**
|
||||
* Represents an album by a specific artist, containing multiple tracks.
|
||||
*
|
||||
* @property albumName The name of the album.
|
||||
* @property artist The artist or band associated with the album.
|
||||
* @property tracks An [Array] of tracks included on the album.
|
||||
*/
|
||||
class Album(val albumName: String, val artist: String, val tracks: Array<Track>) {
|
||||
|
||||
/**
|
||||
* Returns an array of tracks within the specified duration range.
|
||||
*/
|
||||
fun tracksInDurationRange(durationRange: ClosedRange<Duration>): Array<Track> {
|
||||
return this.tracks.filter { it.duration in durationRange }.toTypedArray()
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the total duration of all tracks on the album.
|
||||
*/
|
||||
fun totalDuration(): Duration {
|
||||
var totalDuration: Duration = Duration.ZERO
|
||||
this.tracks.forEach { totalDuration += it.duration }
|
||||
return totalDuration
|
||||
}
|
||||
|
||||
override fun toString(): String {
|
||||
return "${this.albumName} by ${this.artist}\nTotal duration: ${this.totalDuration()}\nTracks:\n${this.tracks.joinToString("\n")}"
|
||||
}
|
||||
}
|
||||
@@ -1,15 +0,0 @@
|
||||
package OOP.Java.lab_6
|
||||
|
||||
import kotlin.time.Duration
|
||||
|
||||
/**
|
||||
* Represents a track in the Dance-pop style.
|
||||
*
|
||||
* @param numberInAlbum The position of the track on the album.
|
||||
* @param trackName The name of the track.
|
||||
* @param feature The featured artist(s) in the track (nullable if no featured artist).
|
||||
* @param duration The [Duration] of the track.
|
||||
*/
|
||||
class Dancepop(numberInAlbum: Int, trackName: String, feature: String?, duration: Duration): Track(numberInAlbum, trackName, feature, duration) {
|
||||
override val style = "Dance-pop"
|
||||
}
|
||||
@@ -1,15 +0,0 @@
|
||||
package OOP.Java.lab_6
|
||||
|
||||
import kotlin.time.Duration
|
||||
|
||||
/**
|
||||
* Represents a track in the Electropop style.
|
||||
*
|
||||
* @param numberInAlbum The position of the track on the album.
|
||||
* @param trackName The name of the track.
|
||||
* @param feature The featured artist(s) in the track (nullable if no featured artist).
|
||||
* @param duration The [Duration] of the track.
|
||||
*/
|
||||
class Electropop(numberInAlbum: Int, trackName: String, feature: String?, duration: Duration): Track(numberInAlbum, trackName, feature, duration) {
|
||||
override val style = "Electropop"
|
||||
}
|
||||
@@ -1,15 +0,0 @@
|
||||
package OOP.Java.lab_6
|
||||
|
||||
import kotlin.time.Duration
|
||||
|
||||
/**
|
||||
* Represents an interlude track.
|
||||
*
|
||||
* @param numberInAlbum The position of the track on the album.
|
||||
* @param trackName The name of the track.
|
||||
* @param feature The featured artist(s) in the track (nullable if no featured artist).
|
||||
* @param duration The [Duration] of the track.
|
||||
*/
|
||||
class Interlude(numberInAlbum: Int, trackName: String, feature: String?, duration: Duration): Track(numberInAlbum, trackName, feature, duration) {
|
||||
override val style = "Interlude"
|
||||
}
|
||||
@@ -1,15 +0,0 @@
|
||||
package OOP.Java.lab_6
|
||||
|
||||
import kotlin.time.Duration
|
||||
|
||||
/**
|
||||
* Represents a track in the Synth-pop style.
|
||||
*
|
||||
* @param numberInAlbum The position of the track on the album.
|
||||
* @param trackName The name of the track.
|
||||
* @param feature The featured artist(s) in the track (nullable if no featured artist).
|
||||
* @param duration The [Duration] of the track.
|
||||
*/
|
||||
class Synthpop(numberInAlbum: Int, trackName: String, feature: String?, duration: Duration): Track(numberInAlbum, trackName, feature, duration) {
|
||||
override val style = "Synth-pop"
|
||||
}
|
||||
@@ -1,27 +0,0 @@
|
||||
package OOP.Java.lab_6
|
||||
|
||||
import kotlin.time.Duration
|
||||
|
||||
/**
|
||||
* Represents a track on an album.
|
||||
*
|
||||
* @param numberInAlbum The position of the track on the album.
|
||||
* @param trackName The name of the track.
|
||||
* @param feature The featured artist(s) in the track (nullable if no featured artist).
|
||||
* @param duration The [Duration] of the track.
|
||||
*/
|
||||
open class Track(val numberInAlbum: Int, val trackName: String, val feature: String?, val duration: Duration) {
|
||||
|
||||
/**
|
||||
* The style or genre of the track.
|
||||
*/
|
||||
open val style = ""
|
||||
|
||||
override fun toString(): String {
|
||||
return if (this.feature == null) {
|
||||
"#${this.numberInAlbum}: ${this.trackName} (${this.duration})"
|
||||
} else {
|
||||
"#${this.numberInAlbum}: ${this.trackName} ft. ${this.feature} (${this.duration})"
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,42 +0,0 @@
|
||||
package OOP.Java.lab_6
|
||||
|
||||
import kotlin.time.Duration.Companion.minutes
|
||||
import kotlin.time.Duration.Companion.seconds
|
||||
|
||||
fun main() {
|
||||
|
||||
val chromatica = Album(
|
||||
"Chromatica",
|
||||
"Lady Gaga",
|
||||
arrayOf(
|
||||
Interlude(1, "Chromatica I", null, 1.minutes),
|
||||
Synthpop(2, "Alice", null, 2.minutes + 57.seconds),
|
||||
Dancepop(3, "Stupid Love", null, 3.minutes + 13.seconds),
|
||||
Dancepop(4, "Rain On Me", "Ariana Grande", 3.minutes + 2.seconds),
|
||||
Synthpop(5, "Free Woman", null, 3.minutes + 11.seconds),
|
||||
Electropop(6, "Fun Tonight", null, 2.minutes + 53.seconds),
|
||||
Interlude(7, "Chromatica II", null, 41.seconds),
|
||||
Synthpop(8, "911", null, 2.minutes + 52.seconds),
|
||||
Electropop(9, "Plastic Doll", null, 3.minutes + 41.seconds),
|
||||
Dancepop(10, "Sour Candy", "Blackpink", 2.minutes + 37.seconds),
|
||||
Dancepop(11, "Enigma", null, 2.minutes + 59.seconds),
|
||||
Synthpop(12, "Replay", null, 3.minutes + 6.seconds),
|
||||
Interlude(13, "Chromatica III", null, 27.seconds),
|
||||
Electropop(14, "Sine From Above", "Elton John", 4.minutes + 4.seconds),
|
||||
Synthpop(15, "1000 Doves", null, 3.minutes + 35.seconds),
|
||||
Dancepop(16, "Babylon", null, 2.minutes + 41.seconds)
|
||||
)
|
||||
)
|
||||
|
||||
println("$chromatica\n")
|
||||
|
||||
println("${chromatica.albumName} tracks sorted by musical style:\n${chromatica.tracks.sortedBy { it.style }.joinToString("\n")}\n")
|
||||
|
||||
val durationRange = 1.minutes.. 3.minutes + 30.seconds
|
||||
|
||||
println(
|
||||
"${chromatica.albumName} tracks in a duration range ($durationRange):\n${chromatica.tracksInDurationRange(durationRange).joinToString("\n")}"
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
11
OOP_IO-2x_2023.iml
Normal file
11
OOP_IO-2x_2023.iml
Normal 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>
|
||||
16
Rust/lab_1/Cargo.lock
generated
16
Rust/lab_1/Cargo.lock
generated
@@ -1,16 +0,0 @@
|
||||
# This file is automatically @generated by Cargo.
|
||||
# It is not intended for manual editing.
|
||||
version = 3
|
||||
|
||||
[[package]]
|
||||
name = "lab_1"
|
||||
version = "0.1.0"
|
||||
dependencies = [
|
||||
"text_io",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "text_io"
|
||||
version = "0.1.12"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "d5f0c8eb2ad70c12a6a69508f499b3051c924f4b1cfeae85bfad96e6bc5bba46"
|
||||
@@ -1,9 +0,0 @@
|
||||
[package]
|
||||
name = "lab_1"
|
||||
version = "0.1.0"
|
||||
edition = "2021"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
[dependencies]
|
||||
text_io = "0.1.12"
|
||||
@@ -1,22 +0,0 @@
|
||||
fn protected_read(variable_name: &str) -> i32 {
|
||||
use text_io::try_read;
|
||||
loop {
|
||||
print!("Enter {}: ", variable_name);
|
||||
let read_result: Result<i32, _> = try_read!();
|
||||
match read_result {
|
||||
Ok(read_integer) => return read_integer,
|
||||
Err(_e) => println!("{} must be an integer!", variable_name.to_uppercase()),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let n: i32 = protected_read("n");
|
||||
let m: i32 = protected_read("m");
|
||||
let a: i32 = protected_read("a");
|
||||
let b: i32 = protected_read("b");
|
||||
|
||||
let s: f32 = ((b + m) as f32 / 2f32) * ((m - b + 1) * (n - a + 1)) as f32;
|
||||
|
||||
println!("S = {}", s);
|
||||
}
|
||||
16
Rust/lab_2/Cargo.lock
generated
16
Rust/lab_2/Cargo.lock
generated
@@ -1,16 +0,0 @@
|
||||
# This file is automatically @generated by Cargo.
|
||||
# It is not intended for manual editing.
|
||||
version = 3
|
||||
|
||||
[[package]]
|
||||
name = "lab_2"
|
||||
version = "0.1.0"
|
||||
dependencies = [
|
||||
"text_io",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "text_io"
|
||||
version = "0.1.12"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "d5f0c8eb2ad70c12a6a69508f499b3051c924f4b1cfeae85bfad96e6bc5bba46"
|
||||
@@ -1,9 +0,0 @@
|
||||
[package]
|
||||
name = "lab_2"
|
||||
version = "0.1.0"
|
||||
edition = "2021"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
[dependencies]
|
||||
text_io = "0.1.12"
|
||||
@@ -1,140 +0,0 @@
|
||||
// #[allow(dead_code)]
|
||||
fn capitalise(s: &str) -> String {
|
||||
let mut c = s.chars();
|
||||
match c.next() {
|
||||
None => String::new(),
|
||||
Some(f) => f.to_uppercase().collect::<String>() + c.as_str(),
|
||||
}
|
||||
}
|
||||
|
||||
fn read_row() -> Vec<i16> {
|
||||
loop {
|
||||
print!("Row (separated by spaces): ");
|
||||
let raw_row: String = text_io::read!("{}\n");
|
||||
let trimmed_row: &str = raw_row.trim();
|
||||
match trimmed_row.split(" ").all(|value| {
|
||||
value.chars().all(|char| char.is_numeric() || char == '-')
|
||||
&& value.parse::<i32>().unwrap() <= i16::MAX as i32
|
||||
&& value.parse::<i32>().unwrap() >= i16::MIN as i32
|
||||
}) {
|
||||
true => {
|
||||
return trimmed_row
|
||||
.split(" ")
|
||||
.map(|value| value.parse::<i16>().unwrap())
|
||||
.collect::<Vec<i16>>()
|
||||
}
|
||||
false => println!("[Error] The row must consist of short integers, try again."),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn generate_row(row_index: u16, length: u16) -> Vec<i16> {
|
||||
return (0..length)
|
||||
.map(|element_index| (element_index as i16 + 1) * (row_index as i16 + 1))
|
||||
.collect();
|
||||
}
|
||||
|
||||
fn read_matrix() -> Vec<Vec<i16>> {
|
||||
let rows: u16 = protected_u16_read("the number of rows");
|
||||
loop {
|
||||
print!("Generate [s]quare or [r]ectangle matrix or [i]nput manually [s/r/i]: ");
|
||||
let option: String = text_io::read!();
|
||||
match option.to_lowercase().as_str() {
|
||||
"s" => return (0..rows).map(|i| generate_row(i, rows)).collect(),
|
||||
"r" => {
|
||||
let columns: u16 = protected_u16_read("the number of columns");
|
||||
return (0..rows).map(|i| generate_row(i, columns)).collect();
|
||||
}
|
||||
"i" => return (0..rows).map(|_| read_row()).collect(),
|
||||
_ => println!("[Error] Not an option, try again."),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn protected_u16_read(variable_name: &str) -> u16 {
|
||||
use text_io::try_read;
|
||||
loop {
|
||||
print!("Enter {}: ", variable_name);
|
||||
let read_result: Result<u16, _> = try_read!();
|
||||
match read_result {
|
||||
Ok(read_integer) => return read_integer,
|
||||
Err(_e) => println!(
|
||||
"{} must be a short integer, try again.",
|
||||
capitalise(variable_name)
|
||||
),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn multiply_matrix_by_number(matrix: &Vec<Vec<i16>>, multiplier: u16) -> Vec<Vec<i16>> {
|
||||
return matrix
|
||||
.iter()
|
||||
.map(|row| {
|
||||
row.iter()
|
||||
.map(|element| element * multiplier as i16)
|
||||
.collect()
|
||||
})
|
||||
.collect();
|
||||
}
|
||||
|
||||
fn average_of_row(row: &Vec<i16>) -> f32 {
|
||||
return row.iter().sum::<i16>() as f32 / row.len() as f32;
|
||||
}
|
||||
|
||||
fn format_matrix(matrix: &Vec<Vec<i16>>) -> String {
|
||||
let max_width = matrix
|
||||
.iter()
|
||||
.map(|row| {
|
||||
row.iter()
|
||||
.map(|element| element.to_string().len())
|
||||
.max()
|
||||
.unwrap()
|
||||
})
|
||||
.max()
|
||||
.unwrap();
|
||||
|
||||
let mut formatted_matrix: String = matrix
|
||||
.iter()
|
||||
.map(|row| {
|
||||
row.iter()
|
||||
.map(|element| format!("| {:max_width$} ", element))
|
||||
.collect::<Vec<String>>()
|
||||
.join("")
|
||||
})
|
||||
.collect::<Vec<String>>()
|
||||
.join("|\n");
|
||||
formatted_matrix.push('|');
|
||||
return formatted_matrix;
|
||||
}
|
||||
|
||||
fn format_column(column: &Vec<f32>) -> String {
|
||||
let max_width = column
|
||||
.iter()
|
||||
.map(|element| element.to_string().len())
|
||||
.max()
|
||||
.unwrap();
|
||||
|
||||
return column
|
||||
.iter()
|
||||
.map(|element| format!("| {:max_width$} |", element))
|
||||
.collect::<Vec<String>>()
|
||||
.join("\n");
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let full_vec_test: Vec<Vec<i16>> = read_matrix();
|
||||
println!("\nMatrix B:\n{}\n", format_matrix(&full_vec_test));
|
||||
|
||||
let mult_full_vec_test: Vec<Vec<i16>> =
|
||||
multiply_matrix_by_number(&full_vec_test, protected_u16_read("matrix multiplier"));
|
||||
println!("Matrix a×B:\n{}\n", format_matrix(&mult_full_vec_test));
|
||||
|
||||
let row_averages: Vec<f32> = mult_full_vec_test
|
||||
.iter()
|
||||
.map(|row| average_of_row(row))
|
||||
.collect();
|
||||
println!(
|
||||
"Averages for each row in a×B:\n{}",
|
||||
format_column(&row_averages)
|
||||
);
|
||||
}
|
||||
140
src/Lab1/Lab1.java
Normal file
140
src/Lab1/Lab1.java
Normal file
@@ -0,0 +1,140 @@
|
||||
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();
|
||||
}
|
||||
}
|
||||
153
src/Lab2/Lab2.java
Normal file
153
src/Lab2/Lab2.java
Normal file
@@ -0,0 +1,153 @@
|
||||
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);
|
||||
}
|
||||
}
|
||||
}
|
||||
73
src/Lab3/Lab3.java
Normal file
73
src/Lab3/Lab3.java
Normal file
@@ -0,0 +1,73 @@
|
||||
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);
|
||||
}
|
||||
}
|
||||
118
src/Lab4/Airplane.java
Normal file
118
src/Lab4/Airplane.java
Normal file
@@ -0,0 +1,118 @@
|
||||
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
|
||||
}
|
||||
}
|
||||
101
src/Lab4/Lab4.java
Normal file
101
src/Lab4/Lab4.java
Normal file
@@ -0,0 +1,101 @@
|
||||
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(), який є прикладом поліморфізму
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
97
src/Lab6/Car.java
Normal file
97
src/Lab6/Car.java
Normal file
@@ -0,0 +1,97 @@
|
||||
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 і використовується для порівняння автомобілів
|
||||
// за споживанням палива.
|
||||
// повертає значення за яким потім буде сортуватися масив машин
|
||||
|
||||
20
src/Lab6/Coupe.java
Normal file
20
src/Lab6/Coupe.java
Normal file
@@ -0,0 +1,20 @@
|
||||
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); // викликаємо супер-метод, додаємо тип кузова
|
||||
}
|
||||
}
|
||||
24
src/Lab6/Hatchback.java
Normal file
24
src/Lab6/Hatchback.java
Normal file
@@ -0,0 +1,24 @@
|
||||
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); // додаємо до супер-методу нову властивість
|
||||
}
|
||||
}
|
||||
23
src/Lab6/Sedan.java
Normal file
23
src/Lab6/Sedan.java
Normal file
@@ -0,0 +1,23 @@
|
||||
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); // додаємо до супер-методу додаткову властивість
|
||||
}
|
||||
}
|
||||
182
src/Lab6/TaxiPark.java
Normal file
182
src/Lab6/TaxiPark.java
Normal file
@@ -0,0 +1,182 @@
|
||||
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);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user