leetcode 1.两数之和(C++)DAY1(待补充哈希表法)

文章目录

  • 1.题目描述
    • 示例
    • 提示
  • 2.解答思路
  • 3.实现代码
  • 结果
  • 4.总结

1.题目描述

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

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

示例

leetcode 1.两数之和(C++)DAY1(待补充哈希表法)_第1张图片

提示

  • 2 <= nums.length <= 104
  • 109 <= nums[i] <= 109
  • 109 <= target <= 109
  • 只会存在一个有效答案

2.解答思路

脑海里最直接想到的是循环遍历两遍nums数组
直接判断循环条件符合时,即可返回相应的下标

3.实现代码

class Solution
{
public:
    vector<int> twoSum(vector<int> &nums, int target)
    {
        int i, j;
        for ( i = 0; i < nums.size(); ++i)
        {
            for ( j = i + 1; j < nums.size(); ++j)
            {
                if (nums[i] + nums[j] == target)
                    return {i, j};
            }
        }
                return {i, j};
    }
};

结果

在这里插入图片描述

4.总结

自己知道是返回两个下标,但不知道该怎么写
return {i, j} ; //这个返回的写法是学来的,
查看题解时发现使用哈希表来查找更加高效,后续学习会补上相关的笔记~

你可能感兴趣的:(C++刷题,c++,算法,leetcode)