2022-6-29
重点是在与使用动态规划的方法开辟一个大小为2的int类型地址空间,建立数组,用于返回。
int *a=(int *)malloc(sizeof(int)) * 2;
- 两数之和
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。
你可以按任意顺序返回答案。
思路:在数组内部进行循环比较,暴力代数,有两个for循环,时间复杂度为O(n*n);
因为很长时间没有写代码,这个查询了相关的题解。重点是在与使用动态规划的方法建立数组,用于返回。
我的C代码:
/**
* Note: The returned array must be malloced, assume caller calls free().
*/
int* twoSum(int* nums, int numsSize, int target, int* returnSize){
int *a=(int *)malloc(sizeof(int) *2); //使用动态规划的方法建立一个大小为2的数组用于之后的返回
//两个for循环嵌套
for(int i=0;i<numsSize;i++)
{
for(int j=i+1;j<numsSize;j++)
{
//判断两个相加是不是等于目标值
if(nums[0]+nums[1]==target)
{
a[0]=i;
a[1]=j;
*returnSize = 2;
return a;
}
}
}
//错误处理
*returnSize = 0;
return a;
}