🔍 两数之和

给定一个整数数组,找出两个下标(从1开始),使对应的值加起来等于目标值。最简单的思路就是两层循环:外层从0开始遍历,如果当前值已经大于target,直接跳过——因为它和任何正数相加都会超过target;内层从i+1开始,检查两数之和。找到后把下标+1存入动态分配的结果数组,并设置*returnSize = 2。没找到的话返回空指针。
int* twoSum(int* numbers, int numbersLen, int target, int* returnSize) {
// write code here
int* ret = (int*)malloc(sizeof(int) * numbersLen);
for (int i = 0; i < numbersLen; i++) {
if (numbers[i] > target) {
continue;
}
for (int j = i + 1; j < numbersLen; j++) {
int sum = numbers[i] + numbers[j];
if (sum == target) {
ret[0] = i + 1;
ret[1] = j + 1;
*returnSize = 2;
return ret;
}
}
}
return 0;
}
🏠 珠玑妙算






