题目:给定一个整数数组和一个目标值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)
方法二:哈希表
大家可以看我的上一篇发表的哈希表内容看看,里面的代码含义跟这个代码时一样的
对这行代码做一下解释,为什么要与上P1->data->Index != i。因为当输入nums=[3,3,4,5],target=6,
需要加上这行代码,不然输入的结果就是[0,0],target-nums[0]=6-3=3;需要找到3的下标,如果没有这行代码的话,他会直接就找到了原来target减去的3的下标,而题目要求下标不能重复出现。
哈希表就是以空间换时间。