A Za, A Za, Fighting...

坚信:勤能补拙

数对之差的最大值

题目:

题目:在数组中,数字减去它右边的数字得到一个数对之差。求所有数对之差的最大值。例如在数组{2, 4, 1, 16, 7, 5, 11, 9}中,数对之差的最大值是11,是16减去5的结果。

对于分治算法,实现的不好,参考原作者的思路,对于左半部分最大值、右半部分最小值都是可以在递归里求出的,参考:

#include<stdio.h>
#include
<stdlib.h>
#include
<assert.h>
#include
<limits.h>
#define MAX(a, b) ((a)>(b) ? (a) : (b))
#define MIN(a, b) ((a)<(b) ? (a) : (b))
/*
 * 题目:
 * 在数组中,数字减去它右边的数字得到一个数对之差。求所有数对之差的最大值
 * 例如:
 * 在数组{2, 4, 1, 16, 7, 5, 11, 9}中,数对之差的最大值是11,是16减去5的结果
 
*/

int
naive_solution(
int *array, int len) //O(n^2)
{
    
int i, j, ret = INT_MIN;
    
for(i=0; i<len; ++i)
        
for(j=i+1; j<len; ++j)
            ret 
= MAX(ret, array[i]-array[j]);

    
return ret;
}

int
divide_and_conquer_solution(
int *array, int begin, int end) //O(nlogn)
{
    
if(begin >= end)
        
return INT_MIN;
    
int i, ret, left_ret, right_ret, left_max, right_min, mid;
    mid 
= begin + ((end-begin)>>1);
    left_ret 
= divide_and_conquer_solution(array, begin, mid);
    right_ret 
= divide_and_conquer_solution(array, mid+1, end);
    left_max 
= array[begin];
    
for(i=begin+1; i<=mid; ++i)
        left_max 
= MAX(left_max, array[i]);
    right_min 
= array[end];
    
for(i=end-1; i>mid; --i)
        right_min 
= MIN(right_min, array[i]);

    ret 
= MAX(left_ret, right_ret);
    ret 
= MAX(ret, left_max-right_min);
    
return ret;
}

int
dynamic_programming_solution(
int *array, int len) //O(n)
{
    
int i, cur_ret, cur_min;
    cur_ret 
= array[len-2- array[len-1];
    cur_min 
= MIN(array[len-2], array[len-1]);

    
for(i=len-3; i>=0--i) {
        cur_ret 
= MAX(cur_ret, array[i]-cur_min);
        cur_min 
= MIN(cur_min, array[i]);
    }

    
return cur_ret;
}

int
main(
int argc, char **argv)
{
    
int i, num, *data = NULL;
    scanf(
"%d"&num);
    assert(num
>=2);
    data 
= (int *)malloc(sizeof(int* num);
    assert(data 
!= NULL);
    
for(i=0; i<num; i++)
        scanf(
"%d", data+i);

    printf(
"naive_solution result: %d\n", naive_solution(data, num));
    printf(
"divide_and_conquer_solution result: %d\n", divide_and_conquer_solution(data, 0, num-1));
    printf(
"dynamic_programming_solution result: %d\n", dynamic_programming_solution(data, num));

    free(data);
    
return 0;
}

posted on 2011-07-26 13:25 simplyzhao 阅读(612) 评论(0)  编辑 收藏 引用 所属分类: M_面试题集锦


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理


导航

<2011年7月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

统计

常用链接

留言簿(1)

随笔分类

随笔档案

搜索

最新评论

阅读排行榜

评论排行榜