Sobes.tech
Назад к вопросам
Senior
5

/ ** * Поиск двух чисел в массиве, сумма которых равна заданному числу * <p> * Напиши функцию, принимающую массив из положительных * неупорядоченных чисел первым аргументом * и положительное число вторым аргументом. * Функция должна возвращать true, если в массиве * есть 2 числа, которые в сумме дают 2-й аргумент. * <p> * Input: ([10, 15, 3, 7], 17) * Output: true */

Компании, где спрашивали
VKVK

Ответ от нейросети

sobes.tech AI

java public class TwoSum { public static boolean hasTwoSum(int[] nums, int target) { Set<Integer> complements = new HashSet<>(); for (int num : nums) { if (complements.contains(num)) { return true; } complements.add(target - num); } return false; }

public static void main(String[] args) {
    int[] arr = {10, 15, 3, 7};
    int target = 17;
    System.out.println(hasTwoSum(arr, target)); // true
}

}


Функция `hasTwoSum` использует множество для хранения "дополняющих" чисел, которые нужны, чтобы в сумме получить `target`. При проходе по массиву, если текущее число есть в множестве, значит найдено два числа, сумма которых равна `target`. Это решение работает за O(n) по времени и O(n) по памяти.