c版本1
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
/*
* 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。
* 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
* 给定 nums = [2, 7, 11, 15], target = 9
* 因为 nums[0] + nums[1] = 2 + 7 = 9
* 所以返回 [0, 1]
*/
/*
* 由题目可以看出返回值为两个数组的下标所以返回一个指针,指针指向数组的两个下标。(函数的返回值只能是一个!)
* 参数:
* nums:数组
* numsSize:数组的长度
* target:目标值
* 返回值:是一个指针假如经过遍历整个数组,发现数组内没有满足和为目标值的元素,则返回空指针
* 说明:
* 由于返回这个数组所以在函数执行完后,接收到返回的指针,且指针指向的内容为两个数组的下标。
* 所以返回的值不能是在(局部变量)栈中创建。*因为函数执行完后为在函数内的局部变量被销毁,
* 所以在动态内存上开辟一块大小为2个整形的大小用来存放返回值,就避免在函数执行完后返回值被销毁了。(别忘了免费)
*/
int* twoSum(int* nums, int numsSize, int target)
{
int i = 0, j = 0;
int* p = NULL;
assert(nums);
int*p = (int*)malloc(2 * sizeof(int));
for(i = 0; i < numsSize - 1; i&