为什么这样不对?希望大家可以来帮帮忙,我想用两个循环一个从前面,一个从后面来寻找,感觉这样快点。可以用C++或者C语言告诉我那里错或者怎么样都行

力扣第一题,不会做,最好使用C语言求解
为什么这样不对?希望大家可以来帮帮忙,我想用两个循环一个从前面,一个从后面来寻找,感觉这样快点。可以用C++或者C语言告诉我那里错或者怎么样都行
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- CSDN专家-深度学习进阶 2022-02-26 16:35关注
第二个for循环数组越界了,b应该最大为numssize-1
如有帮助,请点击我评论上方【采纳该答案】按钮支持一下,谢谢!以后有什么问题可以互相交流。
/** * Note: The returned array must be malloced, assume caller calls free(). */ int* twoSum(int* nums, int numsSize, int target, int* returnSize) { for (int a = 0; a < numsSize; ++a) { for (int b = numsSize-1; b >a; --b) { if (nums[a] + nums[b] == target) { int* ret = malloc(sizeof(int) * 2); ret[0] = a, ret[1] = b; *returnSize = 2; return ret; } } } *returnSize = 0; return NULL; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录