C语言--两数之和

天涯浪子 提交于 2020-02-17 10:25:03

两数之和

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标.

你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素.

示例:

给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
int* twoSum(int* nums, int numsSize, int target, int* returnSize){
   int i, j;
int a, b;
int* array = (int*)malloc(2 * sizeof(int));
for (i = 0; i < numsSize; i++) {
a = target - nums[i];
//nums[i] = 0;
for (j = 0; j < numsSize; j++) {
if (nums[j] == a && i != j) {
array[0] = i;
array[1] = j;
}
}
}
*returnSize = 2;
return array; 
}
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!