
首先我们先来解答一个疑问:为什么新手小白看不懂题解?
别人的题解格式我们从来没见过

但是我们平时学习的格式是

这是因为平时我们写代码需要添加他们的头文件和库函数等,但是在力扣的平台中我们可以直接省略这一步,直接根据他给出的格式写代码。

接下来是题解(C++版本)
题目:

首先先给出代码
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
for (int i = 0; i < nums.size(); i++) {
// 内层循环:只遍历i后面的元素(避免重复使用同一个元素)
for (int j = i + 1; j < nums.size(); j++) {
// 找到和为target的两个数,返回下标
if (nums[i] + nums[j] == target) {
return {i, j};
}
}
}
return {};
}
};
题目解析:
题目要求我们返回数组的下标,这个数组下标对应的值相加等于target
思维:
1、正常思维来说第一步,设置变量,写输入格式
但是上述代码中并没有定义变量,也没有cin输入任何数
这是因为该平台会自动把提前设置好的例子传入,所以并不需要我们自己设置
vector twoSum(vector& nums, int target)
你可以把它理解成「函数的使用说明书」:告诉编译器和开发者 —— 这个函数要接收什么参数、会返回什么结果、叫什么名字。
2、现在我们来理解这个两个嵌套循环
for (int i = 0; i < nums.size(); i++) {
// 内层循环:只遍历i后面的元素(避免重复使用同一个元素)
for (int j = i + 1; j < nums.size(); j++) {
// 找到和为target的两个数,返回下标
if (nums[i] + nums[j] == target) {
return {i, j};
}
}
}
用i表示第一个数,j表示第二个数,nums.size()表示这个数组有几个数,现在用for循环去遍历,找到第一个数,现在题目要求不能使用两次相同的数,则让j在i的基础上往后一位(j=i+1),现在只需要满足,这两个数相加等于target就能够输出该下标。
3、可能会很多人不理解为什么代码中一定需要一个 return {};
vector twoSum(vector& nums, int target)这里我们就规定了必须要有返回值,尽管返回值也可以是一个空的,但是必须要有。如果不加这个 return {};大家可以试一下,会报错。
8万+

被折叠的 条评论
为什么被折叠?



