两数之和OJ链接:1. 两数之和 - 力扣(LeetCode)
题目:
思路:
在读懂题目后很多人觉得这种题目很简单,但是不管怎么写,在VS等其他编译器上能跑成功,但是在LeetCode上就是没办法通过。其实这并不是你的代码出错了,而是没有遵守OJ平台规定而造成的。
切记!切记!切记!一定要学会看注释!!!
很多人就是因为不看注释导致程序总是会编译错误!!!
因为注释都是英文所以需要大家有点英文功底!如果大家以后工作了看的很多文件都是英文的!!!所以学好英语很重要!!!
注释的意思是返回的数组需要malloc申请空间,假设调用者会调用free。
所以需要申请一个新的空间来存放数组!!!
理解了注释,同样理解函数的参数也很重要!!!
int*nums 依据题意可以知道是传数组,而int numsSize中文翻译就是数组的大小,int target依据题目和翻译可知是我们的目标值,最后的int*returnSize根据翻译可知是返回数组的大小(有一说一这个参数纯属没用,容易误导)。
既然没有学过哈希表等高级算法,我们就可以用最简单的枚举暴力解法进行解题。
解题思路:
题目要求在数组里找到两个数之和等于目标数,那么我们可以写一个双层循环,从下标位0的元素开始一次与数组中的每一位数相加,找到元素后,开辟一个新的数组,将对应的下标放到数组内,最后再返回我们的数组。
代码实现:
int* twoSum(int* nums, int numsSize, int target, int* returnSize)
{
for(int i=0;i<numsSize-1;i++)
{
for(int j=i+1;j<numsSize;j++)
{
if(nums[i]+nums[j]==target)//判断两元素相加是否为整数目标值target
{
int *a=(int*)malloc(sizeof(int)*2); //按照提示申请动态数组
a[0]=i;//将得到的元素下标传入数组
a[1]=j;
*returnSize=2;//因为题目要求是两个数组下标,所以返回的数组大小为2
return a;//返回数组
}
}
}
return 0;
}
复杂度分析
-
时间复杂度:O(n²),双重
for
循环 -
空间复杂度:O(1),申请而外空间大小为常数