leetcode--两数之和(C语言)

题目:给定一个整数数组和一个目标值target,从数组中找出两个整数相加等于目标值target,返回他们的下标,假设每个目标值target都对应一个答案,但是返回的下标不能重复。

比如:

①给定一个数组nums=[3,6,8,15,14,7];target=13。则返回下标为arr=[1,5],

nums[1]+nums[5]=6+7=13=target;

②给定一个整数数组nums=[9,2,6,7,5];target=8。返回下标为arr=[1,2],

nums[1]+nums[2]=2+6=target=8

大家先东东脑筋想一下该怎么写代码。

已知代码:

已知源代码:

#define _CRT_SECURE_NO_WARNINGS 1

#include <stdio.h>
#include <stdlib.h>

int* twoSum(int* nums, int numsSize, int target, int* returnSize){
    
}

int main(){
    int target;
    int* nums;
    int* ret;
    int numsSize,i;
    int returnSize;

    //创建数组
    printf("请确定数组的长度:>");
    fflush(stdin);    //清空缓存区
    scanf("%d",&numsSize);
    nums=(int*)malloc(sizeof(int)*numsSize);
    for(i=0;i<numsSize;i++){
        printf("请输入第%d个数组元素:>");
        fflush(stdin);
        scanf("%d",&nums[i]);
    }

    //输入目标值
    printf("请输入目标值target:>");
    fflush(stdin);
    scanf("%d",&target);

    //求解两数之和函数
    ret=twoSum(nums,numsSize,target,&returnSize);

    //打印下标
    for(i=0;i<returnSize;i++)
        printf("%d ",ret[i]);
}

 

答案:

方法1:暴力解法

 

暴力解法的时间复杂度O(n^3),空间复杂度O(1)

方法二:哈希表

大家可以看我的上一篇发表的哈希表内容看看,里面的代码含义跟这个代码时一样的

哈希表基础操作_coding of pig的博客-CSDN博客哈希表基础操作,线性探测法,拉链法https://blog.csdn.net/navylhjjlh/article/details/123983121

对这行代码做一下解释,为什么要与上P1->data->Index != i。因为当输入nums=[3,3,4,5],target=6,

需要加上这行代码,不然输入的结果就是[0,0],target-nums[0]=6-3=3;需要找到3的下标,如果没有这行代码的话,他会直接就找到了原来target减去的3的下标,而题目要求下标不能重复出现。

 

 

 哈希表就是以空间换时间。

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值