From 80ce51464443db2fefa1dbf57a81f312cc563507 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1?= <мфв> Date: Tue, 25 Nov 2025 00:03:25 +0500 Subject: [PATCH] =?UTF-8?q?=D0=93=D1=80=D0=B8=D1=88=D0=B8=D0=BD=20=D0=92?= =?UTF-8?q?=D0=B0=D0=B4=D0=B8=D0=BC=20=D0=9F=D1=80=D0=B8-201=209.1=20-=209?= =?UTF-8?q?.3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- task01/src/com/example/task01/Pair.java | 50 +++++++++++++++++- task01/src/com/example/task01/Task01Main.java | 6 ++- task02/list1.dat | Bin 0 -> 72 bytes task02/list1a.dat | Bin 0 -> 78 bytes task02/list2.dat | Bin 0 -> 1162 bytes task02/list4.dat | Bin 0 -> 155 bytes task02/src/com/example/task02/SavedList.java | 46 +++++++++++++--- task03/src/com/example/task03/Task03Main.java | 35 +++++++++--- testlist.dat | Bin 0 -> 74 bytes 9 files changed, 121 insertions(+), 16 deletions(-) create mode 100644 task02/list1.dat create mode 100644 task02/list1a.dat create mode 100644 task02/list2.dat create mode 100644 task02/list4.dat create mode 100644 testlist.dat diff --git a/task01/src/com/example/task01/Pair.java b/task01/src/com/example/task01/Pair.java index f6fb603b..1912e2b4 100644 --- a/task01/src/com/example/task01/Pair.java +++ b/task01/src/com/example/task01/Pair.java @@ -1,5 +1,51 @@ package com.example.task01; -public class Pair { - // TODO напишите реализацию +import java.util.Objects; +import java.util.Optional; +import java.util.function.BiConsumer; +import java.util.function.Consumer; + +public class Pair { + private final T first; + private final K second; + + private Pair(T first, K second){ + this.first = first; + this.second = second; + } + + public T getFirst(){ + return first; + } + + public K getSecond(){ + return second; + } + + public static Pair of(T first, K second){ + return new Pair<>(first, second); + } + + public void ifPresent(BiConsumer consumer) { + if (first != null && second != null) + consumer.accept(first, second); + } + + public boolean equals(Object obj) { + if (this == obj) { + return true; + } + + if (!(obj instanceof Pair)) { + return false; + } + + Pair other = (Pair) obj; + return Objects.equals(first, other.first) && Objects.equals(second, other.second); + } + + public int hashCode() { + return Objects.hash(first, second); + } + } diff --git a/task01/src/com/example/task01/Task01Main.java b/task01/src/com/example/task01/Task01Main.java index 54dde94f..dc1a1285 100644 --- a/task01/src/com/example/task01/Task01Main.java +++ b/task01/src/com/example/task01/Task01Main.java @@ -2,13 +2,14 @@ import java.io.IOException; import java.io.InputStream; +import java.util.Optional; public class Task01Main { public static void main(String[] args) throws IOException { // TODO С корректно реализованным классом Pair должен компилироваться и успешно работать следующий код: - /* + Pair pair = Pair.of(1, "hello"); Integer i = pair.getFirst(); // 1 String s = pair.getSecond(); // "hello" @@ -21,7 +22,8 @@ public static void main(String[] args) throws IOException { Pair pair2 = Pair.of(1, "hello"); boolean mustBeTrue = pair.equals(pair2); // true! boolean mustAlsoBeTrue = pair.hashCode() == pair2.hashCode(); // true! - */ + System.out.println(mustBeTrue); + System.out.println(mustAlsoBeTrue); } diff --git a/task02/list1.dat b/task02/list1.dat new file mode 100644 index 0000000000000000000000000000000000000000..e09632d32de0890ed6bfc295d1ff21b297459f13 GIT binary patch literal 72 zcmZ4UmVvdnh(S0ju`E%qv?Mb}&#|Z|vC=2AxTK=-lI+amiF2757(E$SiZiQHD+(AG Z7?{dgKx7F6vwvP{2?J|LMp0^N1ps)r7AXJ# literal 0 HcmV?d00001 diff --git a/task02/list1a.dat b/task02/list1a.dat new file mode 100644 index 0000000000000000000000000000000000000000..e23b42f9a735d90d23859e7eda7a1fa0bfaa7dc6 GIT binary patch literal 78 zcmZ4UmVvdnh(S0ju`E%qv?Mb}&#|Z|vC=2AxTK=-lI+amiF2757(E$SiZiQHD+(AG e7?{ghKx7F6vwvPHkPIo$FJWK}$tX%qtpET3&KKMO literal 0 HcmV?d00001 diff --git a/task02/list2.dat b/task02/list2.dat new file mode 100644 index 0000000000000000000000000000000000000000..5f09bec6154ced2ca7c099b43ff047d57d70a008 GIT binary patch literal 1162 zcmYMzJxT;Y5QgEF-9>Zb1y8V8)j!o6nkfh-USNU|XBkvxW_2|47zW`=M>;Kc7@SS^xk5 literal 0 HcmV?d00001 diff --git a/task02/list4.dat b/task02/list4.dat new file mode 100644 index 0000000000000000000000000000000000000000..76e4dedeefb88bd4d9b05d5d6f99998683a3b4d4 GIT binary patch literal 155 zcmZ4UmVvdnh(S0ju`E%qv?Mb}&#|Z|vC=2AxTK=-lI+amiF2757(E$SiZiQHD+(AG z7?{ghKqOF;AXrmQVqUtQXI@EadTNo-qXkR8H?~_afwZueCFYc-RunM^Ak_Jl<|d^U hwXK;d%RS{mHxmN`$Vler#f1!Y3_u extends AbstractList { + private final File file; + private List savedList = new ArrayList<>(); public SavedList(File file) { + this.file = file; + + if (file.exists() && file.isFile()) { + try (ObjectInputStream objectInputStream = new ObjectInputStream( + Files.newInputStream(file.toPath()))) { + + savedList = (List) objectInputStream.readObject(); + + + } catch (IOException | ClassNotFoundException e) { + throw new RuntimeException("Ошибка загрузки данных", e); + } + } } + private void writeToFile() { + try (ObjectOutputStream stream = new ObjectOutputStream(Files.newOutputStream(file.toPath()))) { + stream.writeObject(savedList); + } catch (IOException e) { + throw new RuntimeException("Ошибка записи данных", e); + } + } + + + @Override public E get(int index) { - return null; + return savedList.get(index); } @Override public E set(int index, E element) { - return null; + E Element = savedList.set(index, element); + writeToFile(); + return Element; } @Override public int size() { - return 0; + return savedList.size(); } @Override public void add(int index, E element) { + savedList.add(index, element); + writeToFile(); } @Override public E remove(int index) { - return null; + E Element = savedList.remove(index); + writeToFile(); + return Element; } } diff --git a/task03/src/com/example/task03/Task03Main.java b/task03/src/com/example/task03/Task03Main.java index 7f255e98..0f041fc4 100644 --- a/task03/src/com/example/task03/Task03Main.java +++ b/task03/src/com/example/task03/Task03Main.java @@ -1,11 +1,9 @@ package com.example.task03; -import java.io.FileInputStream; -import java.io.IOException; -import java.io.InputStream; +import java.io.*; import java.nio.charset.Charset; -import java.util.List; -import java.util.Set; +import java.util.*; +import java.util.stream.Collectors; public class Task03Main { @@ -19,6 +17,31 @@ public static void main(String[] args) throws IOException { } public static List> findAnagrams(InputStream inputStream, Charset charset) { - return null; + Map> result = new TreeMap<>(); + try (BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, charset))) { + List lines = reader.lines() + .map(String::toLowerCase) + .filter(str -> str.matches("[а-яё]+") && str.length() >= 3) + .distinct() + .collect(Collectors.toList()); + + for (String line : lines) { + char[] symbols = line.toCharArray(); + Arrays.sort(symbols); + String key = new String(symbols); + result.computeIfAbsent(key, value -> new TreeSet<>()).add(line); + } + + } catch (Exception e) { + return new ArrayList<>(); + } + + return result.values() + .stream() + .filter(value -> value.size() >= 2) + .collect(Collectors.toList()); } + + + } diff --git a/testlist.dat b/testlist.dat new file mode 100644 index 0000000000000000000000000000000000000000..a438cb56536475eb9d3994aa3798ed4fcac60bca GIT binary patch literal 74 zcmZ4UmVvdnh(S0ju`E%qv?Mb}&#|Z|vC=2AxTK=-lI+amiF2757(E$SiZiQHD+(AG R7+A_#Kx7F6V-zy3005j~6<+`V literal 0 HcmV?d00001