Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 19 additions & 9 deletions task01/src/com/example/task01/Task01Main.java
Original file line number Diff line number Diff line change
@@ -1,29 +1,39 @@
package com.example.task01;

import java.io.IOException;
import java.util.Objects;
import java.util.function.Function;
import java.util.function.Predicate;

public class Task01Main {
public static void main(String[] args) throws IOException {
public static void main(String[] args) {

// TODO С корректно реализованным методом ternaryOperator должен компилироваться и успешно работать следующий код:

/*
Predicate<Object> condition = Objects::isNull;
Function<Object, Integer> ifTrue = obj -> 0;
Function<CharSequence, Integer> ifFalse = CharSequence::length;
Function<String, Integer> safeStringLength = ternaryOperator(condition, ifTrue, ifFalse);
*/


System.out.println(safeStringLength.apply(null)); // 0
System.out.println(safeStringLength.apply("Hello")); // 5
}

public static <T, U> Function<T, U> ternaryOperator(
Predicate<? super T> condition,
Function<? super T, ? extends U> ifTrue,
Function<? super T, ? extends U> ifFalse) {

return null; // your implementation here

Function<? super T, ? extends U> ifFalse)
{

Objects.requireNonNull(condition, "Condition null");
Objects.requireNonNull(ifTrue, "IfTrue null");
Objects.requireNonNull(ifFalse, "IfFalse null");

return t -> {
if (condition.test(t)) {
return ifTrue.apply(t);
} else {
return ifFalse.apply(t);
}
};
}
}
29 changes: 22 additions & 7 deletions task02/src/com/example/task02/Task02Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,22 +2,37 @@

import java.util.stream.IntStream;

import java.util.stream.IntStream;
import java.util.stream.Stream;

public class Task02Main {

public static void main(String[] args) {

/*
cycleGrayCode(2)
.limit(10)
.forEach(System.out::println);
*/
cycleGrayCode(2).limit(10).forEach(System.out::println);
cycleGrayCode(3).limit(10).forEach(System.out::println);
cycleGrayCode(4).limit(10).forEach(System.out::println);

}

public static IntStream cycleGrayCode(int n) {
if (n < 1 || n > 16) {
throw new IllegalArgumentException("Error: n < 1 || n > 16");
}

return null; // your implementation here
int[] grayCodes = generateGrayCodes(n);

return IntStream.iterate(0, i -> (i + 1) % grayCodes.length).map(i -> grayCodes[i]);
}

}
private static int[] generateGrayCodes(int n) {
int size = 1 << n;
int[] grayCodes = new int[size];

for (int i = 0; i < size; i++) {
grayCodes[i] = i ^ (i >> 1);
}

return grayCodes;
}
}
43 changes: 40 additions & 3 deletions task03/src/com/example/task03/Task03Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -4,24 +4,61 @@
import java.util.function.BiConsumer;
import java.util.stream.Stream;

import java.util.*;
import java.util.stream.Collectors;

public class Task03Main {

public static void main(String[] args) {

findMinMax(
Stream.of(2, 9, 5, 4, 8, 1, 3),
Integer::compareTo,
(min, max) ->
System.out.println("min: " + min + " / max: " + max)
(min, max) -> System.out.println("min: " + min + " / max: " + max)
);

findMinMax(
Stream.empty(),
Integer::compareTo,
(min, max) -> System.out.println("min: " + min + " / max: " + max)
);
}

public static <T> void findMinMax(
Stream<? extends T> stream,
Comparator<? super T> order,
BiConsumer<? super T, ? super T> minMaxConsumer) {

// your implementation here
Objects.requireNonNull(stream, "Stream null");
Objects.requireNonNull(order, "Comparator null");
Objects.requireNonNull(minMaxConsumer, "BiConsumer null");

Optional<T> min = Optional.empty();
Optional<T> max = Optional.empty();

Iterator<? extends T> iterator = stream.iterator();

if (!iterator.hasNext()) {
minMaxConsumer.accept(null, null);
return;
}

T first = iterator.next();
min = Optional.of(first);
max = Optional.of(first);

while (iterator.hasNext()) {
T current = iterator.next();

if (current == null || (min.isPresent() && order.compare(current, min.get()) < 0)) {
min = Optional.of(current);
}

if (current == null || (max.isPresent() && order.compare(current, max.get()) > 0)) {
max = Optional.of(current);
}
}

minMaxConsumer.accept(min.orElse(null), max.orElse(null));
}
}
39 changes: 35 additions & 4 deletions task04/src/com/example/task04/Task04Main.java
Original file line number Diff line number Diff line change
@@ -1,11 +1,42 @@
package com.example.task04;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;
import java.util.Arrays;
import java.util.Comparator;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.function.ToLongFunction;
import java.util.stream.Collectors;
import java.util.stream.Stream;

public class Task04Main {

public static void main(String[] args) {
public static void main(String[] args) throws IOException {

// your implementation here
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in, StandardCharsets.UTF_8));
String input = reader.readLine().toLowerCase();

}
String[] words = input.split("[^\\p{L}\\p{N}]+");

Map<String, Long> wordFrequency = Arrays.stream(words)
.collect(Collectors.groupingBy(word -> word, Collectors.counting()));

}
Map<String, Long> sortedByFrequencyAndAlphabet = wordFrequency
.entrySet()
.stream()
.sorted(Map.Entry.<String, Long>comparingByValue()
.reversed()
.thenComparing(Map.Entry.comparingByKey()))
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue,
(oldValue, newValue) -> oldValue, LinkedHashMap::new));

sortedByFrequencyAndAlphabet.entrySet().stream()
.limit(10)
.map(Map.Entry::getKey)
.forEach(System.out::println);

}
}
27 changes: 27 additions & 0 deletions task05/src/com/example/task05/MailMessage.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
package com.example.task05;

public class MailMessage implements Sendable<String> {
private final String from;
private final String to;
private final String content;

public MailMessage(String from, String to, String content) {
this.from = from;
this.to = to;
this.content = content;
}

public String getFrom() {
return from;
}

@Override
public String getTo() {
return to;
}

@Override
public String getContent() {
return content;
}
}
18 changes: 18 additions & 0 deletions task05/src/com/example/task05/MailService.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package com.example.task05;

import java.util.*;
import java.util.function.Consumer;
public class MailService<T> implements Consumer<Sendable<T>> {
private final Map<String, List<T>> mailBox = new HashMap<>();

public Map<String, List<T>> getMailBox() {
return mailBox;
}

@Override
public void accept(Sendable<T> sendable) {
List<T> list = mailBox.getOrDefault(sendable.getTo(), new ArrayList<>());
list.add(sendable.getContent());
mailBox.put(sendable.getTo(), list);
}
}
27 changes: 27 additions & 0 deletions task05/src/com/example/task05/Salary.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
package com.example.task05;

public class Salary implements Sendable<Integer> {
private final String from;
private final String to;
private final int amount;

public Salary(String from, String to, int amount) {
this.from = from;
this.to = to;
this.amount = amount;
}

public String getFrom() {
return from;
}

@Override
public String getTo() {
return to;
}

@Override
public Integer getContent() {
return amount;
}
}
6 changes: 6 additions & 0 deletions task05/src/com/example/task05/Sendable.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
package com.example.task05;

public interface Sendable<T> {
String getTo();
T getContent();
}
12 changes: 3 additions & 9 deletions task05/src/com/example/task05/Task05Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,15 @@
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.*;

public class Task05Main {

public static void main(String[] args) {

/*

// Random variables
String randomFrom = "..."; // Некоторая случайная строка. Можете выбрать ее самостоятельно.
String randomTo = "..."; // Некоторая случайная строка. Можете выбрать ее самостоятельно.
String randomFrom = "RandomSender"; // Некоторая случайная строка. Можете выбрать ее самостоятельно.
String randomTo = "RandomRecipient"; // Некоторая случайная строка. Можете выбрать ее самостоятельно.
int randomSalary = 100; // Некоторое случайное целое положительное число. Можете выбрать его самостоятельно.

// Создание списка из трех почтовых сообщений.
Expand Down Expand Up @@ -86,10 +85,5 @@ public static void main(String[] args) {
assert salaries.get(salary1.getTo()).equals(Arrays.asList(1)) : "wrong salaries mailbox content (1)";
assert salaries.get(salary2.getTo()).equals(Arrays.asList(Integer.MAX_VALUE)) : "wrong salaries mailbox content (2)";
assert salaries.get(randomTo).equals(Arrays.asList(randomSalary)) : "wrong salaries mailbox content (3)";


*/

}

}