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
13 changes: 7 additions & 6 deletions task01/src/com/example/task01/Task01Main.java
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package com.example.task01;

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

Expand All @@ -9,21 +10,21 @@ public static void main(String[] args) throws IOException {

// 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));
System.out.println(safeStringLength.apply(""));
System.out.println(safeStringLength.apply("Java-funtional-stream"));
}

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

if (condition == null || ifTrue == null || ifFalse == null) throw new NullPointerException();
return t -> condition.test(t) ? ifTrue.apply(t) : ifFalse.apply(t);
}
}
9 changes: 2 additions & 7 deletions task02/src/com/example/task02/Task02Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,14 @@
public class Task02Main {

public static void main(String[] args) {

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

}

public static IntStream cycleGrayCode(int n) {

return null; // your implementation here

if (n > 16 || n < 1) throw new IllegalArgumentException();
return IntStream.iterate(0, x -> (x + 1) % (1 << n)).map(x -> x ^ (x >> 1));
}

}
18 changes: 17 additions & 1 deletion task03/src/com/example/task03/Task03Main.java
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package com.example.task03;

import java.util.Comparator;
import java.util.Iterator;
import java.util.function.BiConsumer;
import java.util.stream.Stream;

Expand All @@ -22,6 +23,21 @@ public static <T> void findMinMax(
Comparator<? super T> order,
BiConsumer<? super T, ? super T> minMaxConsumer) {

// your implementation here
Iterator<? extends T> iterator = stream.iterator();
if (!iterator.hasNext()) minMaxConsumer.accept(null, null);
else {
T min = iterator.next();
T max = min;
while (iterator.hasNext()) {
T current = iterator.next();
if (order.compare(current, min) < 0) {
min = current;
}
else if (order.compare(current, max) > 0) {
max = current;
}
}
minMaxConsumer.accept(min, max);
}
}
}
22 changes: 21 additions & 1 deletion task04/src/com/example/task04/Task04Main.java
Original file line number Diff line number Diff line change
@@ -1,10 +1,30 @@
package com.example.task04;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.sql.SQLOutput;
import java.util.Comparator;
import java.util.Map;
import java.util.stream.Collectors;
import java.util.stream.Stream;

public class Task04Main {

public static void main(String[] args) {

// your implementation here
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
reader.lines()
.map(String::toLowerCase)
.flatMap(line -> Stream.of(line.split("[^\\p{L}\\p{N}]+")))
.filter(word -> !word.isEmpty())
.collect(Collectors.groupingBy(word -> word, Collectors.counting()))
.entrySet()
.stream()
.sorted(Map.Entry.comparingByKey())
.sorted(Map.Entry.comparingByValue(Comparator.reverseOrder()))
.limit(10)
.map(Map.Entry::getKey)
.forEach(word -> System.out.print(word + "\n"));

}

Expand Down
7 changes: 7 additions & 0 deletions task05/src/com/example/task05/Mail.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package com.example.task05;

public interface Mail<T> {
String getFrom();
String getTo();
T getContent();
}
28 changes: 28 additions & 0 deletions task05/src/com/example/task05/MailMessage.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
package com.example.task05;

public class MailMessage implements Mail<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;
}

@Override
public String getFrom() {
return from;
}

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

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

import java.util.*;
import java.util.function.Consumer;

public class MailService<T> implements Consumer<Mail<T>> {
private final Map<String, List<T>> mailBox = new HashMap<>();

@Override
public void accept(Mail<T> mail) {
mailBox.computeIfAbsent(mail.getTo(), k -> new ArrayList<>()).add(mail.getContent());
}

public Map<String, List<T>> getMailBox() {
return new AbstractMap<String, List<T>>() {
@Override
public Set<Entry<String, List<T>>> entrySet() {
return Collections.emptySet();
}

@Override
public List<T> get(Object key) {
List<T> result = mailBox.get(key);
return result != null ? result : Collections.emptyList();
}
};
}
}
28 changes: 28 additions & 0 deletions task05/src/com/example/task05/Salary.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
package com.example.task05;

public class Salary implements Mail<Integer> {
private final String from;
private final String to;
private final Integer salary;

public Salary(String from, String to, Integer salary) {
this.from = from;
this.to = to;
this.salary = salary;
}

@Override
public String getFrom() {
return from;
}

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

@Override
public Integer getContent() {
return salary;
}
}
4 changes: 0 additions & 4 deletions task05/src/com/example/task05/Task05Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ public class Task05Main {

public static void main(String[] args) {

/*

// Random variables
String randomFrom = "..."; // Некоторая случайная строка. Можете выбрать ее самостоятельно.
Expand Down Expand Up @@ -87,9 +86,6 @@ public static void main(String[] args) {
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)";


*/

}

}