Rust 两数之和 一遍HashMap

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。

解决方案:

 判断target - nums[i] 是否存在Map中,之后把nums[i]插入Map.

 use std::collections::HashMap;
 let mut map = HashMap::new();
    for (index, n) in nums.iter().enumerate() {
        if let Some(ans) = map.get(n) {
            return vec![index as i32, *ans as i32];
        }
        map.insert(target - n, index);
    }
  unreachable!()

 

posted @ 2020-07-28 16:09  州长在手  阅读(303)  评论(0编辑  收藏  举报