码迷,mamicode.com
首页 > 其他好文 > 详细

1. Two Sum

时间:2016-03-12 09:06:58      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:

Given an array of integers, return indices of the two numbers such that they add up to a specific target.

You may assume that each input would have exactly one solution.

Example:
Given nums = [2, 7, 11, 15], target = 9,

Because nums[0] + nums[1] = 2 + 7 = 9,
return [0, 1].

typedef struct MyNum{
    int num;
    int index;
}MyNum;

int* twoSum(int* nums, int numsSize, int target) {
    int start = 0;
    int end = numsSize-1;
    int* result = NULL;
    MyNum* myNums;
    int sum;
    
    if(numsSize < 2) return result;
    
    result = malloc(sizeof(int)*2);
    myNums = malloc(sizeof(MyNum)*numsSize);
    for(int i = 0; i < numsSize; i++){
        myNums[i].num = nums[i];
        myNums[i].index = i;
    }
    
    quickSort(myNums, start, end);

    sum = myNums[start].num+myNums[end].num;
    while(sum != target){
        if(sum > target) end--;
        else start++;
        sum = myNums[start].num+myNums[end].num;
    }
    
    if(myNums[start].index <= myNums[end].index){
        result[0] = myNums[start].index;
        result[1] = myNums[end].index;
    }
    else{
        result[1] = myNums[start].index;
        result[0] = myNums[end].index;
    }
    return result;
}

void quickSort(MyNum* nums, int start, int end){
    int p1 = start+1; 
    int p2 = end;
    MyNum tmp;

    while(p1 <= p2){
        while(p1 <= p2 && nums[p1].num <= nums[start].num ){
            p1++;
        }
        while(p1 <= p2 && nums[p2].num > nums[start].num ){
            p2--;
        }
        if(p1 < p2){
            tmp = nums[p1];
            nums[p1] = nums[p2];
            nums[p2] = tmp;
            p1++;
            p2--;
        }
    }

    //put the sentinel at the end of the first subarray
    if(start!=p2){
    tmp = nums[start];
    nums[start] = nums[p2];
    nums[p2] = tmp;
    }
            
    if(start < p2-1) quickSort(nums,start, p2-1); //sort first subarray (<=sentinel)
    if(p1 < end) quickSort(nums,p1, end); //sort second subarray  (>sentinel)
}

 

1. Two Sum

标签:

原文地址:http://www.cnblogs.com/qionglouyuyu/p/5267871.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!