Sobes.tech
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. Если да — возвращаем индексы.