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
11 changes: 5 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,19 @@ 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<Object, Integer> ifTrue = obj -> 0; Function<CharSequence, Integer> ifFalse = CharSequence::length;
Function<String, Integer> safeStringLength = ternaryOperator(condition, ifTrue, ifFalse);
*/

}

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);
}
}
16 changes: 11 additions & 5 deletions task02/src/com/example/task02/Task02Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,25 @@
public class Task02Main {

public static void main(String[] args) {

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

}

public static IntStream cycleGrayCode(int n) {
if (n < 1 || n > 16) {
throw new IllegalArgumentException("n должно быть от 1 до 16");
}

int totalNumbers = 1 << n;
int[] grayCodes = new int[totalNumbers];

return null; // your implementation here
for (int i = 0; i < totalNumbers; i++) {
grayCodes[i] = i ^ (i >> 1);
}

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

}
22 changes: 21 additions & 1 deletion task03/src/com/example/task03/Task03Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import java.util.Comparator;
import java.util.function.BiConsumer;
import java.util.stream.Stream;
import java.util.Iterator;

public class Task03Main {

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

// your implementation here
Iterator<? extends T> iterator = stream.iterator();
T min = null;
T max = null;

if (iterator.hasNext()){
min = iterator.next();
max = min;
}

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

if (order.compare(currentElement,min) < 0)
min = currentElement;

if (order.compare(currentElement,max) > 0)
max = currentElement;
}

minMaxConsumer.accept(min,max);
}
}
24 changes: 21 additions & 3 deletions task04/src/com/example/task04/Task04Main.java
Original file line number Diff line number Diff line change
@@ -1,11 +1,29 @@
package com.example.task04;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Comparator;
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) {

// your implementation here

BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
reader.lines()
.map(String::toLowerCase)
.flatMap(x -> Stream.of(x.split("[^a-zа-яё0-9]")))
.filter(x -> !x.isEmpty())
.collect(Collectors.groupingBy(x -> x, Collectors.counting()))
.entrySet()
.stream()
.sorted(Comparator.comparingLong((ToLongFunction<Map.Entry<String,Long>>) Map.Entry::getValue)
.reversed()
.thenComparing(Map.Entry::getKey))
.limit(10)
.forEach(t -> System.out.print(t.getKey() + "\n"));
}

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

public interface MailContent<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 MailContent<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;
}
}
31 changes: 31 additions & 0 deletions task05/src/com/example/task05/MailService.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
package com.example.task05;

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

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

@Override
public void accept(MailContent<T> mailContent) {
String to = mailContent.getTo();
T content = mailContent.getContent();

mailBox.computeIfAbsent(to, k -> new ArrayList<>()).add(content);
}

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

@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 MailContent<Integer> {
private final String from;
private final String to;
private final int salary;

public Salary(String from, String to, int 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;
}
}
11 changes: 2 additions & 9 deletions task05/src/com/example/task05/Task05Main.java
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,9 @@
public class Task05Main {

public static void main(String[] args) {

/*

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

// Создание списка из трех почтовых сообщений.
Expand Down Expand Up @@ -86,10 +83,6 @@ 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)";


*/

}

}