Back to questions
МВидео
Senior
1
// Дан массив целых чисел nums и целое число target // Нужно найти два числа, сумма которых равняется target и вернуть их индексы // Считаем, что существует ровно одно решение и нельзя использовать один элемент дважды // Ответ можно возвращать в любом порядке // Примеры: // [2,7,11,15], target = 9, ответ [0,1] (nums[0] + nums[1] == 9) // [3,2,4], target = 6, ответ [1,2] (nums[1] + nums[2] == 6) // [3,3], target = 6, ответ [0,1] (nums[0] + nums[1] == 6)
Companies where asked
Answer from AI
sobes.tech AI
Ниже пример решения задачи на Go с использованием хэш-таблицы для поиска пары чисел, сумма которых равна target:
func twoSum(nums []int, target int) []int {
indices := make(map[int]int) // ключ — число, значение — индекс
for i, num := range nums {
complement := target - num
if j, found := indices[complement]; found {
return []int{j, i}
}
indices[num] = i
}
return nil // если решения нет (по условию всегда есть)
}
// Пример использования:
// nums := []int{2,7,11,15}
// target := 9
// result := twoSum(nums, target) // result == [0,1]
Идея: проходим по массиву, для каждого элемента проверяем, встречали ли мы ранее число, которое в сумме с текущим даст target. Если да — возвращаем индексы.