• 分治法求最大最小


    
    

      分治法的基本思想:是将一个规模为n的原问题分解为k个规模较小的子问题,这些子问题互相独立且与原问题相同。递归地解这些子问题,然后将子问题的解合并为原问题的解。

     1 #include<stdio.h>
     2 /* 分治法计算最大值和最小值的算法程序,递归实现 */
     3 void maxmin2(int d[], int left, int right, int *max, int *min) //数组,头,尾,最大值,最小值 
     4 {
     5     int max1, min1;
     6                                                       //递归最小时处理 
     7     if(left==right) {                              //如果只有一个数 即使最大也是最小 
     8         *max = d[left];
     9         *min = d[left];
    10     } else if(left == right-1) {                    //两个数,判断大小 
    11         if(d[left] > d[right]){
    12             *max = d[left];
    13             *min = d[right];
    14         } else {
    15             *max = d[right];
    16             *min = d[left];
    17         }
    18     } else {
    19         int mid = (left + right) / 2;                 //二分 
    20         maxmin2(d, left, mid, &max1, &min1);          //处理左端 
    21         maxmin2(d, mid+1, right, &max1, &min1);       //处理右端   
    22         if(*max < max1)                                  // 先分后治 
    23             *max = max1;
    24         if(*min > min1)
    25             *min = min1;
    26     }
    27 }
    28 
    29 int main()
    30 {
    31     int d[10] = {0,1,2,3,4,5,6,7,8,9};
    32     int max,min;
    33     maxmin2(d,0,9,&max,&min);
    34     printf("%d %d",max,min);
    35 }
  • 相关阅读:
    PostMan使用教程(1)
    测试工作量的评估方法
    Jmeter之Bean shell使用(二)
    centos7 编译安装redis
    Centos7 安装mariadb
    Centos7 安装使用virtualenvwrapper
    Centos7安装python3.6
    linux基础命令2
    linux基础命令
    linux目录结构
  • 原文地址:https://www.cnblogs.com/Dicer/p/8533086.html
Copyright © 2020-2023  润新知