分治法的经典问题——求数列中最大最小值

前面我们已经了解了分治法的原理和使用,分治法的经典问题——大整数相乘,趁热打铁,来学习一下如何使用分治法来求数列中的最大最小值。

这里写图片描述

利用分治法来分析

这里写图片描述

伪代码

这里写图片描述

时间复杂性

这里写图片描述

代码实现

#include<cstdio>
#include<cstdlib>
#include<cmath>

using namespace std;

int* getmaxmin(int a, int b){
    int* m = new int[2];
    if(a < b){
        m[0] = a;
        m[1] = b;
    }else{
        m[0] = b;
        m[1] = a;
    }
    printf("getmaxmin的值:%d, %d\n", m[0], m[1]);
    return m;
}

//m[0]存放最小值,m[1]存放最大值 
int* maxmin(int a[], int n1, int n2){
    if((n2 - n1 + 1)== 1){
        int* m = new int[2];
        m[0] = -1;
        m[1] = a[n2];
        return getmaxmin(a[n2], a[n2]);
    }else if((n2 - n1 + 1) == 2){
        return getmaxmin(a[n1], a[n2]);
    }else{
        int k = n1 + (n2 - n1) / 2;
        int* lm = maxmin(a, n1, k);
        int* rm = maxmin(a, k+1, n2);

        printf("lm得到的值:%d, %d\n", lm[0], lm[1]);
        if(rm[0] == -1){
            printf("rm得到的值:%d\n", rm[1]);
        }
        printf("rm得到的值:%d, %d\n", rm[0], rm[1]);

        int* result = new int[2];
        if(lm[0] < rm[0]){
            result[0] = lm[0];
        }else{
            result[0] = rm[0];
        }
        if(lm[1] < rm[1]){
            result[1] = rm[1];
        }else{
            result[1] = lm[1];
        }
        return result;
    }
}

int main(){
    int a[8] = {6,10,32,8,19,20,2,14};
    int* result = maxmin(a, 0, 7);
    printf("最大值为:%d,最小值为:%d", result[1], result[0]);
}

结果如下:

这里写图片描述

  • 4
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值