leetcode 题解~两数之和 ~ C++做法

0 前言

最近打算把之前的东西捡起来,毕竟我实在是太水了,如果连这点东西都没有的话,那就真的太说不过去了。

1 实现

题目

给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。

你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。

示例

给定 nums = [2, 7, 11, 15], target = 9,因为 nums[0] + nums[1] = 2 + 7 = 9,所以返回 [0, 1]

题目链接:https://leetcode-cn.com/problems/two-sum/description/

思路

目标值就是 target,求出两个下标 i、j,要使得 nums[i] + nums[j] = target,返回下标。

代码

#include<iostream>
#include<vector>
#include<unordered_map>
using namespace std;

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
/*这里定义了两个顺序容器*/
        vector<int> v(2);  //创建一个向量存储容器 int,元素个数为 2
        for(int i = 0; i < nums.size(); i++) {  
/*nums.size()就是 nums 中元素的个数,for 循环,从第一个数开始循环,直到小于nums.size(),也就是 4 就结束循环*/
            for(int j = i + 1; j < nums.size(); j++) {  //和上面差不多,也是 for 循环
                if(nums[i] + nums[j] == target) {  //进行判断,如果 nums[i] 加 nums[j]等于目标值,那么就进入下面
                    v[0] = i;  //把 i 的值赋给 v[0]
                    v[1] = j;  //把 j 的值赋给 v[1]
                    return v;  //返回 v
                }
            }
        }
    }
};

代码来自:https://www.liuchuo.net/archives/1006 (点击阅读原文可见)

我太水了,只能通过写注释来理解代码。

题图:Photo by Badder Manaouch on Unsplash

原文发布于微信公众号 - 伪君子的梦呓(beiyue_lbj)

原文发表时间:2018-06-21

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏前端儿

ASCII码排序

输入第一行输入一个数N,表示有N组测试数据。后面的N行输入多组数据,每组输入数据都是占一行,有三个字符组成,之间无空格。输出对于每组输入数据,输出一行,字符中间...

1882
来自专栏黑泽君的专栏

java基础学习_基础语法(下)02_day06总结

============================================================================= ==...

611
来自专栏数据结构与算法

洛谷P3273 [SCOI2011]棘手的操作

题目描述 有N个节点,标号从1到N,这N个节点一开始相互不连通。第i个节点的初始权值为a[i],接下来有如下一些操作:U x y: 加一条边,连接第x个节点和第...

3307
来自专栏用户画像

7.6.2 内部排序算法的应用

1)若n较小(N<=50),则可以采用直接插入排序或简单选择排序。由于直接插入排序所需的记录移动操作较简单选择排序多,因而当记录本身信息量较大时,用简单选择排序...

701
来自专栏小樱的经验随笔

洛谷 P1019 单词接龙【经典DFS,温习搜索】

P1019 单词接龙 题目描述 单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”...

3816
来自专栏个人分享

二维数组中的查找

在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该...

1102
来自专栏数据结构与算法

23:二维数组回形遍历

23:二维数组回形遍历 总时间限制: 1000ms 内存限制: 65536kB描述 给定一个row行col列的整数数组array,要求从array[0][0...

5106
来自专栏数据结构与算法

洛谷P3357 最长k可重线段集问题(费用流)

题目描述http://www.cnblogs.com/zwfymqz/p/8559566.html 给定平面 x-O-yx−O−y 上 nn 个开线段组成的集合...

4106
来自专栏技术杂谈

给出一组非负整数,重新排序组成最大的数

先把对比的数字转成字符,拼接后再转成整数进行大小对比,即 int(a+b) 与 int(b+a) 进行降序排列。代码1。

6098
来自专栏Petrichor的专栏

numpy: np.where

Note : 不接受 list 型的参数,只接受 `ndarray 型输入。

1203

扫码关注云+社区

领取腾讯云代金券