🔥6👨💻3👌1
🔍 Ответ на задачу про вычисление среднего двух чисел в Java:
👉 Рассмотрим код:
static double average(int x, int y) {
return (x + y) / 2;
}
public static void main(String[] args) {
System.out.println(average(0,1));
}
Что напечатает программа? 🤔
Метод average принимает два int, возвращает double.
(x + y) / 2 — деление целых чисел, результат тоже будет целым (int). Только в конце оно автоконвертируется в double.
Для average(0, 1):
(0 + 1) / 2 = 1 / 2 = 0 (целое деление!)
💡 Вернётся 0.0 (так как double)
✏️ Если хотите получить десятичное число, нужно хотя бы одно число привести к double:
return (x + y) / 2.0;
Тогда результат будет 0.5!
❗️ Не забывайте про особенности целочисленного деления в Java!
Если было полезно — ставьте лайк❤️, подписывайтесь и пишите комментарии!
#java #javacode #программирование #интервью #java_interview_tasks
👉 Рассмотрим код:
static double average(int x, int y) {
return (x + y) / 2;
}
public static void main(String[] args) {
System.out.println(average(0,1));
}
Что напечатает программа? 🤔
Метод average принимает два int, возвращает double.
(x + y) / 2 — деление целых чисел, результат тоже будет целым (int). Только в конце оно автоконвертируется в double.
Для average(0, 1):
(0 + 1) / 2 = 1 / 2 = 0 (целое деление!)
💡 Вернётся 0.0 (так как double)
✏️ Если хотите получить десятичное число, нужно хотя бы одно число привести к double:
return (x + y) / 2.0;
Тогда результат будет 0.5!
❗️ Не забывайте про особенности целочисленного деления в Java!
Если было полезно — ставьте лайк❤️, подписывайтесь и пишите комментарии!
#java #javacode #программирование #интервью #java_interview_tasks
Telegram
Java Interview Tasks
Что напечатает код?
❤10🔥8👍3
Что напечатает код?
Anonymous Quiz
42%
3
22%
4
3%
0
18%
будет ексепшн
4%
будет что-то другое
13%
узнать ответ
🔥5😁3🤯3👍2
🔍 Ответ на задачу про преобразование List в Map в Java
Давайте разберём, что произойдёт в этом коде:
🔸 Мы превращаем список строк в Map, где ключ — длина строки, а значение — сама строка.
📌 Важно: toMap по умолчанию выбрасывает исключение, если встречает дубликаты ключей (а у нас ключи — длины строк).
При первом попадании строки длины 3 ("one") всё ок. Но когда попадётся "two" — возникнет конфликт ключей!
❗️ Результат: Код выбросит исключение типа IllegalStateException: Duplicate key
То есть ничего не напечатает, а программа упадёт с ошибкой.
✅ Если хотите избежать ошибки — добавьте в toMap третий аргумент (как решать конфликт):
🔔 Было полезно? Ставь лайк, подписывайся и пиши свои вопросы или комменты!
#java #stream #map #interview #toMap #java_interview_tasks
Давайте разберём, что произойдёт в этом коде:
List<String> list = Arrays.asList("one", "two", "three", "four");
Map<Integer, String> size2Str = list.stream()
.collect(Collectors.toMap(String::length, Function.identity()));
System.out.println(size2Str.size()); 🔸 Мы превращаем список строк в Map, где ключ — длина строки, а значение — сама строка.
📌 Важно: toMap по умолчанию выбрасывает исключение, если встречает дубликаты ключей (а у нас ключи — длины строк).
При первом попадании строки длины 3 ("one") всё ок. Но когда попадётся "two" — возникнет конфликт ключей!
❗️ Результат: Код выбросит исключение типа IllegalStateException: Duplicate key
То есть ничего не напечатает, а программа упадёт с ошибкой.
✅ Если хотите избежать ошибки — добавьте в toMap третий аргумент (как решать конфликт):
.collect(Collectors.toMap(String::length, Function.identity(), (s1, s2) -> s1))
// Этот вариант оставит первое значение.
🔔 Было полезно? Ставь лайк, подписывайся и пиши свои вопросы или комменты!
#java #stream #map #interview #toMap #java_interview_tasks
Telegram
Java Interview Tasks
Что напечатает код?
👍20🔥4❤2 1
🔥5👍2❤1 1
🔍 Ответ на задачу про рекурсию, try-catch и counter:
Что там происходит?
Каждый раз в try печатается "do" и выбрасывается исключение. Затем в catch, если counter <= 3 (а это true до значения 3 включительно), снова вызывается doWithCounter, увеличивая counter при этом!
⚠️ Но! Используется counter++, а не ++counter. Это значит, что в рекурсивный вызов идёт старое значение (а counter увеличится уже после передачи в функцию).
То есть вы всегда передаёте "0" в рекурсию, и создаётся бесконечная рекурсия.
❗️Первый вызов поймает исключение, зайдёт в catch и вызовет doWithCounter(0). Этот вызов опять напечатает "do" и опять вызовет doWithCounter(0), и так далее, пока не случится StackOverflowError. "do" будет выводиться до переполнения стека.
📢 Правильный ответ: "do" напечатается более 4-х раз.
👉 Было интересно? Ставь лайк, подписывайся и пиши вопросы в комментарии!
#java #recursion #exception #interview #стек #java_interview_tasks
Что там происходит?
Каждый раз в try печатается "do" и выбрасывается исключение. Затем в catch, если counter <= 3 (а это true до значения 3 включительно), снова вызывается doWithCounter, увеличивая counter при этом!
⚠️ Но! Используется counter++, а не ++counter. Это значит, что в рекурсивный вызов идёт старое значение (а counter увеличится уже после передачи в функцию).
То есть вы всегда передаёте "0" в рекурсию, и создаётся бесконечная рекурсия.
❗️Первый вызов поймает исключение, зайдёт в catch и вызовет doWithCounter(0). Этот вызов опять напечатает "do" и опять вызовет doWithCounter(0), и так далее, пока не случится StackOverflowError. "do" будет выводиться до переполнения стека.
📢 Правильный ответ: "do" напечатается более 4-х раз.
👉 Было интересно? Ставь лайк, подписывайся и пиши вопросы в комментарии!
#java #recursion #exception #interview #стек #java_interview_tasks
Telegram
Java Interview Tasks
Сколько раз напечатается "do"?
👍8🔥6❤1
Какой интерфейс в Java используется для сортировки?
Anonymous Quiz
6%
CompareTo
74%
Comparator
7%
Sort
13%
Sortable
🔥5❤1👍1
🔍 Друзья, разберёмся, какой интерфейс в Java используется для сортировки объектов! (Ответ на вопрос про интерфейсы для сравнения)
Правильный ответ: Comparator и Comparable.
Но из списка в впоросе верный вариант — Comparator!
Интерфейс Comparator используется для задания порядка сортировки объектов, когда нельзя или не хочется изменять сам класс объекта.
Для справки:
CompareTo, Sort и Sortable — таких интерфейсов в стандартной библиотеке Java нет.
👀 Пример применения Comparator:
Если было полезно — ставьте лайк, подписывайтесь на канал и пишите в комментариях, что бы ещё разобрать! 😉
#java_interview_tasks #java #интервью #собеседование #сортировка #Comparator #Comparable
Правильный ответ: Comparator и Comparable.
Но из списка в впоросе верный вариант — Comparator!
Интерфейс Comparator используется для задания порядка сортировки объектов, когда нельзя или не хочется изменять сам класс объекта.
Для справки:
CompareTo, Sort и Sortable — таких интерфейсов в стандартной библиотеке Java нет.
👀 Пример применения Comparator:
List<String> list = Arrays.asList("Java", "Python", "C++");
Collections.sort(list, new Comparator<String>() {
@Override
public int compare(String s1, String s2) {
return s1.length() - s2.length();
}
});
System.out.println(list); // [Java, C++, Python]Если было полезно — ставьте лайк, подписывайтесь на канал и пишите в комментариях, что бы ещё разобрать! 😉
#java_interview_tasks #java #интервью #собеседование #сортировка #Comparator #Comparable
Telegram
Java Interview Tasks
Какой интерфейс в Java используется для сортировки?
CompareTo / Comparator / Sort / Sortable
CompareTo / Comparator / Sort / Sortable
👍9🔥5🤗2❤1
Forwarded from Spring АйО
This media is not supported in your browser
VIEW IN TELEGRAM
Теперь можно вызывать действия прямо из окна автодополнения. А если дважды нажать точку (..), появится список всех доступных действий.
Если зайдёт — добавят и в другие IDE. Выглядит удобно.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤4 2👍1🔥1