LeetCode每日一题——两数之和

两数之和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),申请而外空间大小为常数
PS:OJ题是不用写主函数的噢,大家不要纳闷为啥没有主函数,因为主函数在人家LeetCode服务
器里!!!

PS:看到这里了,码字不易,给个一键三连鼓励一下吧!有不足或者错误之处欢迎在评论区指出!   
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值